本文實例為大家分享了C# DateTime預設可選的日期范圍的相關代碼,可以選擇本年度、本季度、本月等,供大家參考,具體內容如下
效果:
大家在做報表或查詢的時候都會有給用戶預設一些可選的日期范圍(如上圖)
如本年度銷售額、本季度利潤、本月新增客戶
C#裡內置的DateTime基本上都可以實現這些功能,巧用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();
//如果你還不明白,再看一下中文顯示星期幾的方法就應該懂了
//由於DayOfWeek返回的是數字的星期幾,我們要把它轉換成漢字方便我們閱讀,有些人可能會用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號,最後一天就是下個月一號再減一天。當然這是對的
//一般的寫法
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比較
我在日志摘要中曾經用到了日期的比較,我需要比較出發布日志的時間和當前的日期比較,如果是在三天內發布的,那麼我就要在這個日志的前面加上“新”字。
我以前的算法很麻煩,就是將字符串轉換成整形,然後再計算。
我想用DateTime來直接比較。我首先將發布日期(字符串)轉換成日期型:
/計算發布日期
DateTime PubDate=
new
DateTime();
// PubDate=item["創建者"];
string strPubDate=item[
"創建者"
].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);
結果,總是出錯。原因在哪裡呢?
我跟蹤調試了一下,發現了問題的所在。當發布的日志在每月的28日以後,由於直接在轉換的時候加了3,比如29+3=32,32是沒有辦法轉換成日期型的。
所以,我就糾正了這個錯誤,然後在比較的時候,用DateTime.Adddays(3)來完成這個操作:
//計算當前日期
DateTime CurrentDate=
new
DateTime();
CurrentDate=DateTime.Now;
if
(CurrentDate<DT1.ADDDAYS(3))
{
str=str+
" !新"
;
}
如果,您只想比較日期是否相等的話,您可以用DateTime.Compare(dt1,dt2).
以上就是本文的全部內容,希望對大家的學習有所幫助。