C#里巧用DateTime預(yù)設(shè)一些可選的日期范圍(如本
系統(tǒng)
2901 0
//
大家在做報表或查詢的時候都會有給用戶預(yù)設(shè)一些可選的日期范圍(如上圖)
//
如本年度銷售額、本季度利潤、本月新增客戶
//
C#里內(nèi)置的DateTime基本上都可以實現(xiàn)這些功能,巧用DateTime會使你處理這些事來變輕松多了
//
今天
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)換成漢字方便我們閱讀,有些人可能會用switch來一個一個地對照,其實不用那么麻煩的
string
[]Day
=
new
string
[]
{
"
星期日
"
,
"
星期一
"
,
"
星期二
"
,
"
星期三
"
,
"
星期四
"
,
"
星期五
"
,
"
星期六
"
}
;
Day[Convert.ToInt16(DateTime.Now.DayOfWeek)];
//
上周,同理,一個周是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();
//
本月,很多人都會說本月的第一天嘛肯定是1號,最后一天就是下個月一號再減一天。當(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();
//
上個月,減去一個月份
DateTime.Parse(DateTime.Now.ToString(
"
yyyy-MM-01
"
)).AddMonths(
-
1
).ToShortDateString();
DateTime.Parse(DateTime.Now.ToString(
"
yyyy-MM-01
"
)).AddDays(
-
1
).ToShortDateString();
//
下個月,加去一個月份
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();
//
本季度,很多人都會覺得這里難點,需要寫個長長的過程來判斷。其實不用的,我們都知道一年四個季度,一個季度三個月
//
首先我們先把日期推到本季度第一個月,然后這個月的第一天就是本季度的第一天了
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ā)布日志的時間和當(dāng)前的日期比較,如果是在三天內(nèi)發(fā)布的,那么我就要在這個日志的前面加上“新”字。
我以前的算法很麻煩,就是將字符串轉(zhuǎn)換成整形,然后再計算。
我想用DateTime來直接比較。我首先將發(fā)布日期(字符串)轉(zhuǎn)換成日期型:
/計算發(fā)布日期
DateTime PubDate=new DateTime();
//PubDate=item["創(chuàng)建者"];
string strPubDate=item["創(chuàng)建者"].ToString();
DateTime dt1=new DateTime(DateTime.Parse(strPubDate));
在最開始的時候,我直接就在上面這個語句中加了三天,語句就是這樣的了:
DateTime dt1=new DateTime(int.Parse(strY),int.Parse(strM),(
int.Parse(strD)+3),
0,0,0,0);
結(jié)果,總是出錯。原因在哪里呢?
我跟蹤調(diào)試了一下,發(fā)現(xiàn)了問題的所在。當(dāng)發(fā)布的日志在每月的28日以后,由于直接在轉(zhuǎn)換的時候加了3,比如29+3=32,32是沒有辦法轉(zhuǎn)換成日期型的。
所以,我就糾正了這個錯誤,然后在比較的時候,用DateTime.Adddays(3)來完成這個操作:
//計算當(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è)一些可選的日期范圍(如本年度、本季度、本月等)
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061
微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元