在 C# 中相關的時間判斷、計算與相互轉換。
在 .NET 中並沒有「直覺」的方法取得兩個 DateTime 物件之間的差異天數、月數。
*目前時間
DateTime dt = DateTime.Now;
*日期時間相加減
DateTime start = Convert.ToDateTime("2011-04-25 15:50:39");
DateTime end = Convert.ToDateTime("2011-05-02 15:50:39");
TimeSpan ts = end.Subtract(start); //兩時間天數相減
double dayCount = ts.Days; //相距天數
*本周周一
DateTime startWeek = dt.AddDays(1 - Convert.ToInt32(dt.DayOfWeek.ToString("d")));
*本周周日
DateTime endWeek = startWeek.AddDays(6);
*本月月初
DateTime startMonth = dt.AddDays(1 - dt.Day);
*本月月末
DateTime endMonth = startMonth.AddMonths(1).AddDays(-1);
*本月月末
DateTime endMonth = startMonth.AddDays((dt.AddMonths(1) - dt).Days - 1);
*本季初
DateTime startQuarter = dt.AddMonths(0 - (dt.Month - 1) % 3).AddDays(1 - dt.Day);
*本季末
DateTime endQuarter = startQuarter.AddMonths(3).AddDays(-1);
*本年年初
DateTime startYear = new DateTime(dt.Year, 1, 1);
*本年年末
DateTime endYear = new DateTime(dt.Year, 12, 31);
*上周一
DateTime.Now.AddDays(Convert.ToInt32 (1 - Convert.ToInt32(DateTime.Now.DayOfWeek)) - 7);
*上周末(星期日)
DateTime.Now.AddDays(Convert.ToInt32 (1 - Convert.ToInt32(DateTime.Now.DayOfWeek)) - 7).AddDays(6);
*下周一
DateTime.Now.AddDays(Convert.ToInt32 (1 - Convert.ToInt32(DateTime.Now.DayOfWeek)) + 7);
*下周末
DateTime.Now.AddDays(Convert.ToInt32(1 - Convert.ToInt32(DateTime.Now.DayOfWeek)) + 7).AddDays(6);
//本月,很多人都會說本月的第一天肯定是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)).AddDays(1 - DateTime.Now.Day);
*同理,本季度的最後一天就是下季的第一天減一
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)). AddDays(1 - DateTime.Now);
DateTime.Now.AddMonths(0 - ((DateTime.Now.Month - 1) % 3)).AddDays(1 - DateTime.Now.Day).AddDays(-1).ToShortDateString();
*日期時間轉型
如:"20100101"轉換成日期型別
"20100101"轉換成int型別
1、DateTime dt=Convert.ToDateTime("20100101".Substring(0,4)+"-"+"20100101".Substring(4,2)+"-"+"20071107".Substring(6,2));
int i=Convert.ToInt32("20100101");
2、Convert.ToDateTime、DateTime.Parse()
3、string str = "20100101";
DateTime dt = DateTime.ParseExact(str, "yyyyMMdd", null);
int i;
int.TryParse(str, out i);
4、定義一個DateTimePicker對象,將需要轉化的字串賦予DateTimePicker的Text屬性,
然後DateTimePicker的Value值就是你需要的日期和時間,Value值還有Minite,Second等屬性,可以取得時,分,秒,豪秒等值.
參考資料來源:
http://blog.miniasp.com/post/2008/01/22/Find-the-difference-between-two-DateTime.aspx