//
大家在做報(bào)表或查詢的時(shí)候都會(huì)有給用戶預(yù)設(shè)一些可選的日期范圍(如上圖)
//
如本年度銷售額、本季度利潤、本月新增客戶
//
C#里內(nèi)置的DateTime基本上都可以實(shí)現(xiàn)這些功能,巧用DateTime會(huì)使你處理這些事來變輕松多了
//
今天
DateTime.Now.Date.ToShortDateString();
//
昨天,就是今天的日期減一
DateTime.Now.AddDays(
-
1
).ToShortDateString();
//
明天,同理,加一
DateTime.Now.AddDays(
1
).ToShortDateString();
//
本周(要知道本周的第一天就得先知道今天是星期幾,從而得知本周的第一天就是幾天前的那一天,要注意的是這里的每一周是從周日始至周六止
DateTime.Now.AddDays(Convert.ToDouble((
0
-
Convert.ToInt16(DateTime.Now.DayOfWeek)))).ToShortDateString();
DateTime.Now.AddDays(Convert.ToDouble((
6
-
Convert.ToInt16(DateTime.Now.DayOfWeek)))).ToShortDateString();
//
如果你還不明白,再看一下中文顯示星期幾的方法就應(yīng)該懂了
//
由于DayOfWeek返回的是數(shù)字的星期幾,我們要把它轉(zhuǎn)換成漢字方便我們閱讀,有些人可能會(huì)用switch來一個(gè)一個(gè)地對照,其實(shí)不用那么麻煩的
string
[]Day
=
new
string
[]
{
"
星期日
"
,
"
星期一
"
,
"
星期二
"
,
"
星期三
"
,
"
星期四
"
,
"
星期五
"
,
"
星期六
"
}
;
Day[Convert.ToInt16(DateTime.Now.DayOfWeek)];
//
上周,同理,一個(gè)周是7天,上周就是本周再減去7天,下周也是一樣
DateTime.Now.AddDays(Convert.ToDouble((
0
-
Convert.ToInt16(DateTime.Now.DayOfWeek)))
-
7
).ToShortDateString();
DateTime.Now.AddDays(Convert.ToDouble((
6
-
Convert.ToInt16(DateTime.Now.DayOfWeek)))
-
7
).ToShortDateString();
//
下周
DateTime.Now.AddDays(Convert.ToDouble((
0
-
Convert.ToInt16(DateTime.Now.DayOfWeek)))
+
7
).ToShortDateString();
DateTime.Now.AddDays(Convert.ToDouble((
6
-
Convert.ToInt16(DateTime.Now.DayOfWeek)))
+
7
).ToShortDateString();
//
本月,很多人都會(huì)說本月的第一天嘛肯定是1號(hào),最后一天就是下個(gè)月一號(hào)再減一天。當(dāng)然這是對的
//
一般的寫法
DateTime.Now.Year.ToString()
+
DateTime.Now.Month.ToString()
+
"
1
"
;
//
第一天
DateTime.Parse(DateTime.Now.Year.ToString()
+
DateTime.Now.Month.ToString()
+
"
1
"
).AddMonths(
1
).AddDays(
-
1
).ToShortDateString();
//
最后一天
//
巧用C#里ToString的字符格式化更簡便
DateTime.Now.ToString(
"
yyyy-MM-01
"
);
DateTime.Parse(DateTime.Now.ToString(
"
yyyy-MM-01
"
)).AddMonths(
1
).AddDays(
-
1
).ToShortDateString();
//
上個(gè)月,減去一個(gè)月份
DateTime.Parse(DateTime.Now.ToString(
"
yyyy-MM-01
"
)).AddMonths(
-
1
).ToShortDateString();
DateTime.Parse(DateTime.Now.ToString(
"
yyyy-MM-01
"
)).AddDays(
-
1
).ToShortDateString();
//
下個(gè)月,加去一個(gè)月份
DateTime.Parse(DateTime.Now.ToString(
"
yyyy-MM-01
"
)).AddMonths(
1
).ToShortDateString();
DateTime.Parse(DateTime.Now.ToString(
"
yyyy-MM-01
"
)).AddMonths(
2
).AddDays(
-
1
).ToShortDateString();
//
7天后
DateTime.Now.Date.ToShortDateString();
DateTime.Now.AddDays(
7
).ToShortDateString();
//
7天前
DateTime.Now.AddDays(
-
7
).ToShortDateString();
DateTime.Now.Date.ToShortDateString();
//
本年度,用ToString的字符格式化我們也很容易地算出本年度的第一天和最后一天
DateTime.Parse(DateTime.Now.ToString(
"
yyyy-01-01
"
)).ToShortDateString();
DateTime.Parse(DateTime.Now.ToString(
"
yyyy-01-01
"
)).AddYears(
1
).AddDays(
-
1
).ToShortDateString();
//
上年度,不用再解釋了吧
DateTime.Parse(DateTime.Now.ToString(
"
yyyy-01-01
"
)).AddYears(
-
1
).ToShortDateString();
DateTime.Parse(DateTime.Now.ToString(
"
yyyy-01-01
"
)).AddDays(
-
1
).ToShortDateString();
//
下年度
DateTime.Parse(DateTime.Now.ToString(
"
yyyy-01-01
"
)).AddYears(
1
).ToShortDateString();
DateTime.Parse(DateTime.Now.ToString(
"
yyyy-01-01
"
)).AddYears(
2
).AddDays(
-
1
).ToShortDateString();
//
本季度,很多人都會(huì)覺得這里難點(diǎn),需要寫個(gè)長長的過程來判斷。其實(shí)不用的,我們都知道一年四個(gè)季度,一個(gè)季度三個(gè)月
//
首先我們先把日期推到本季度第一個(gè)月,然后這個(gè)月的第一天就是本季度的第一天了
DateTime.Now.AddMonths(
0
-
((DateTime.Now.Month
-
1
)
%
3
)).ToString(
"
yyyy-MM-01
"
);
//
同理,本季度的最后一天就是下季度的第一天減一
DateTime.Parse(DateTime.Now.AddMonths(
3
-
((DateTime.Now.Month
-
1
)
%
3
)).ToString(
"
yyyy-MM-01
"
)).AddDays(
-
1
).ToShortDateString();
//
下季度,相信你們都知道了。。。。收工
DateTime.Now.AddMonths(
3
-
((DateTime.Now.Month
-
1
)
%
3
)).ToString(
"
yyyy-MM-01
"
);
DateTime.Parse(DateTime.Now.AddMonths(
6
-
((DateTime.Now.Month
-
1
)
%
3
)).ToString(
"
yyyy-MM-01
"
)).AddDays(
-
1
).ToShortDateString();
//
上季度
DateTime.Now.AddMonths(
-
3
-
((DateTime.Now.Month
-
1
)
%
3
)).ToString(
"
yyyy-MM-01
"
);
DateTime.Parse(DateTime.Now.AddMonths(
0
-
((DateTime.Now.Month
-
1
)
%
3
)).ToString(
"
yyyy-MM-01
"
)).AddDays(
-
1
).ToShortDateString();
DateTime比較
我在日志摘要中曾經(jīng)用到了日期的比較,我需要比較出發(fā)布日志的時(shí)間和當(dāng)前的日期比較,如果是在三天內(nèi)發(fā)布的,那么我就要在這個(gè)日志的前面加上“新”字。
我以前的算法很麻煩,就是將字符串轉(zhuǎn)換成整形,然后再計(jì)算。
我想用DateTime來直接比較。我首先將發(fā)布日期(字符串)轉(zhuǎn)換成日期型:
/計(jì)算發(fā)布日期
DateTime PubDate=new DateTime();
//PubDate=item["創(chuàng)建者"];
string strPubDate=item["創(chuàng)建者"].ToString();
DateTime dt1=new DateTime(DateTime.Parse(strPubDate));
在最開始的時(shí)候,我直接就在上面這個(gè)語句中加了三天,語句就是這樣的了:
DateTime dt1=new DateTime(int.Parse(strY),int.Parse(strM),(
int.Parse(strD)+3),
0,0,0,0);
結(jié)果,總是出錯(cuò)。原因在哪里呢?
我跟蹤調(diào)試了一下,發(fā)現(xiàn)了問題的所在。當(dāng)發(fā)布的日志在每月的28日以后,由于直接在轉(zhuǎn)換的時(shí)候加了3,比如29+3=32,32是沒有辦法轉(zhuǎn)換成日期型的。
所以,我就糾正了這個(gè)錯(cuò)誤,然后在比較的時(shí)候,用DateTime.Adddays(3)來完成這個(gè)操作:
//計(jì)算當(dāng)前日期
DateTime CurrentDate=new DateTime();
CurrentDate=DateTime.Now;
if(CurrentDate<DT1.ADDDAYS(3))
{
str=str+"
!新
";
}
如果,您只想比較日期是否相等的話,您可以用DateTime.Compare(dt1,dt2).
引用自
http://www.cnblogs.com/shinings/archive/2009/08/05/1539358.html
C#里巧用DateTime預(yù)設(shè)一些可選的日期范圍(如本年度、本季度、本月等)