.net中取到本日,本周,本月,是怎么取得

.net中取到本日,本周,本月,是怎么取得,第1张

我想你的意思应该是要获取2个值,一个开始时间一个结束时间,然后再传值到数据库查询位于这个时间段内的记录吧

前台代码:

<asp:RadioButtonList ID="RadioButtonList1" runat="server">

<asp:ListItem>本日</asp:ListItem>

<asp:ListItem>本周</asp:ListItem>

<asp:ListItem>本月</asp:ListItem>

</asp:RadioButtonList>

<asp:Button ID="Button1" runat="server" onclick="Button1_Click" Text="Button" />

后台代码:

protected void Button1_Click(object sender, EventArgs e)

{

string beginTime="",endTime="";

switch (RadioButtonList1SelectedValue)

{

//本日时间是从当天00:00:00到23:59:59;

case "本日": beginTime = DateTimeNowToString("d") + " 00:00:00"; endTime = DateTimeNowToString("d")+" 23:59:59"; break;

//获取本周时间段,嵌套一个switch语句块,得到本周星期一0点到星期天23点的时间段;

case "本周": switch (DateTimeNowDayOfWeek) //

{

/星期一/case DayOfWeekMonday: beginTime = DateTimeNowToString("d") + " 00:00:00"; endTime = DateTimeNowAddDays(6)ToString("d") + " 23:59:59"; break;

/星期二/case DayOfWeekTuesday: beginTime = DateTimeNowAddDays(-1)ToString("d") + " 00:00:00"; endTime = DateTimeNowAddDays(5)ToString("d") + " 23:59:59"; break;

/星期三/case DayOfWeekWednesday: beginTime = DateTimeNowAddDays(-2)ToString("d") + " 00:00:00"; endTime = DateTimeNowAddDays(4)ToString("d") + " 23:59:59"; break;

//后面周4到周日根据上面计算即可

} break;

//获取本月时间段,开始时间是本月1号,而下个月1号减去1天就是本月最后一天;

case "本月": beginTime = DateTimeNowToString("yyyy-MM") + "-01 00:00:00"; endTime = DateTimeParse(DateTimeNowAddMonths(1)ToString("yyyy-MM") + "-01 00:00:00")AddDays(-1)ToString("d")+" 23:59:59"; break;

}

ResponseWrite("选择的时间段是:" + beginTime + "至" + endTime);//此时beginTime和endTime还是string类型,转换成DateTime类型传值到数据库即可;

}

复制代码

代码如下:

echo

date("Ymd",strtotime("now")),

"\n";

echo

date("Ymd",strtotime("-1

week

Monday")),

"\n";

echo

date("Ymd",strtotime("-1

week

Sunday")),

"\n";

echo

date("Ymd",strtotime("+0

week

Monday")),

"\n";

echo

date("Ymd",strtotime("+0

week

Sunday")),

"\n";

//date('n')

第几个月

//date("w")

本周周几

//date("t")

本月天数

echo

'<br>上周:<br>';

echo

date("Y-m-d

H:i:s",mktime(0,

0

,

0,date("m"),date("d")-date("w")+1-7,date("Y"))),"\n";

echo

date("Y-m-d

H:i:s",mktime(23,59,59,date("m"),date("d")-date("w")+7-7,date("Y"))),"\n";

echo

'<br>本周:<br>';

echo

date("Y-m-d

H:i:s",mktime(0,

0

,

0,date("m"),date("d")-date("w")+1,date("Y"))),"\n";

echo

date("Y-m-d

H:i:s",mktime(23,59,59,date("m"),date("d")-date("w")+7,date("Y"))),"\n";

echo

'<br>上月:<br>';

echo

date("Y-m-d

H:i:s",mktime(0,

0

,

0,date("m")-1,1,date("Y"))),"\n";

echo

date("Y-m-d

H:i:s",mktime(23,59,59,date("m")

,0,date("Y"))),"\n";

echo

'<br>本月:<br>';

echo

date("Y-m-d

H:i:s",mktime(0,

0

,

0,date("m"),1,date("Y"))),"\n";

echo

date("Y-m-d

H:i:s",mktime(23,59,59,date("m"),date("t"),date("Y"))),"\n";

$getMonthDays

=

date("t",mktime(0,

0

,

0,date('n')+(date('n')-1)%3,1,date("Y")));//本季度未最后一月天数

echo

'<br>本季度:<br>';

echo

date('Y-m-d

H:i:s',

mktime(0,

0,

0,date('n')-(date('n')-1)%3,1,date('Y'))),"\n";

echo

date('Y-m-d

H:i:s',

mktime(23,59,59,date('n')+(date('n')-1)%3,$getMonthDays,date('Y'))),"\n";

提倡了一下中文写,

static public void main(String 参数[]){

SimpleDateFormat 格式=new SimpleDateFormat("y年M月d日 E H时m分s秒",LocaleCHINA);

Calendar 日历=CalendargetInstance(LocaleCHINA);

//当前时间,貌似多余,其实是为了所有可能的系统一致

日历setTimeInMillis(SystemcurrentTimeMillis());

Systemoutprintln("当前时间:"+格式format(日历getTime()));

日历set(CalendarDAY_OF_WEEK, CalendarMONDAY);

Systemoutprintln("周一时间:"+格式format(日历getTime()));

}

===========

改到后天测了一下

输出

当前时间:2011年8月31日 星期三 12时32分40秒

周一时间:2011年8月29日 星期一 12时32分40秒

获取本周一

 public static Date getNowWeekMonday(Date date) {    

            Calendar cal = CalendargetInstance();    

             calsetTime(date);    

                  

             caladd(CalendarDAY_OF_MONTH, -1); //解决周日会出现 并到下一周的情况    

            calset(CalendarDAY_OF_WEEK, CalendarMONDAY);    

                 

303            return calgetTime();    

        }

获取上周一

public static Date getLastWeekMonday(Date date) {    

             Date a = DateUtilsaddDays(date, -1);    

            Calendar cal = CalendargetInstance();    

            calsetTime(a);    

            caladd(CalendarWEEK_OF_YEAR, -1);// 一周    

            calset(CalendarDAY_OF_WEEK, CalendarMONDAY);    

                  

             return calgetTime();    

        }

获取上周日

public static Date  getLastWeekSunday(Date date) {    

                 

            Date a = DateUtilsaddDays(date, -1);    

           Calendar cal = CalendargetInstance();    

         calsetTime(a);    

           calset(CalendarDAY_OF_WEEK, 1);    

                 

          return calgetTime();    

        }

代码里面有用到 lapachecommon-ang包 你需要下载下 就可以使用

这个可以用dwr框架来做,你可以google一下dwr框架,是前台页面通过js直接调用后台方法的轻量级框架。

至于时间算法

1显示本周,那得算出当前周的周一到周7(国外是周日到周六为一周)是几号到几号。 方法是:

private static HashMap<String, String> getWeekByDate() {

HashMap<String, String> dayMap = new HashMap<String, String>();

SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); // 设置时间格式

Calendar cal = CalendargetInstance();

calsetTime(new Date());

// 判断要计算的日期是否是周日,如果是则减一天计算周六的,否则会出问题,计算到下一周去了

int dayWeek = calget(CalendarDAY_OF_WEEK);// 获得当前日期是一个星期的第几天

if (1 == dayWeek) {

caladd(CalendarDAY_OF_MONTH, -1);

}

Systemoutprintln("要计算日期为:" + sdfformat(calgetTime())); // 输出要计算日期

calsetFirstDayOfWeek(CalendarMONDAY);// 设置一个星期的第一天,按中国的习惯一个星期的第一天是星期一

int day = calget(CalendarDAY_OF_WEEK);// 获得当前日期是一个星期的第几天

caladd(CalendarDATE, calgetFirstDayOfWeek() - day);// 根据日历的规则,给当前日期减去星期几与一个星期第一天的差值

String imptimeBegin = sdfformat(calgetTime());

Systemoutprintln("所在周星期一的日期:" + imptimeBegin);

dayMapput("Monday", imptimeBegin);

caladd(CalendarDATE, 6);

String imptimeEnd = sdfformat(calgetTime());

Systemoutprintln("所在周星期日的日期:" + imptimeEnd);

dayMapput("SunDay", imptimeEnd);

return dayMap;

}

得到了周一和周日具体是那天,直接去数据库查就OK了,怎么查可以去看下SQL里的between关键字

还有一些写不下,追问一下

<php

//这个月的 周日-周六的日期

$year = date("Y");

$month = date("m");

$days = date("t");

for ($i=0; $i < $days; $i++) { 

$day = $year'-'$month'-'$i;

$w = date('w',strtotime($day));

  if ($w == 6 || $w ==0) {

  echo $day' 是周末<br />';

  }

><php

//这个周的 周日-周六的日期

$year = date("Y");

$month = date("m");

$days = date("t");

$hao = date('j');

for ($i=$hao; $i < ($hao+7); $i++) { 

$day = $year'-'$month'-'$i;

$w = date('w',strtotime($day));

  if ($w == 6 || $w ==0) {

  echo $day' 是周末<br />';

  }

}

>

望采纳 Thx

以上就是关于.net中取到本日,本周,本月,是怎么取得全部的内容,包括:.net中取到本日,本周,本月,是怎么取得、用php获取本周,上周,本月,上月,本季度日期的代码、java 获取当前日期时间和本周的星期一的日期时间等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9275010.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-26
下一篇 2023-04-26

发表评论

登录后才能评论

评论列表(0条)

保存