C#有关日期的使用方法

  1 DateTime dt = DateTime.Now;  //当前时间
  2
  3 DateTime startWeek = dt.AddDays(1 - Convert.ToInt32(dt.DayOfWeek.ToString("d")));  //本周周一
  4 DateTime endWeek = startWeek.AddDays(6);  //本周周日
  5
  6 DateTime startMonth = dt.AddDays(1 - dt.Day);  //本月月初
  7 DateTime endMonth = startMonth.AddMonths(1).AddDays(-1);  //本月月末
  8 DateTime endMonth = startMonth.AddDays((dt.AddMonths(1) - dt).Days - 1);  //本月月末
  9
 10 DateTime startQuarter = dt.AddMonths(0 - (dt.Month - 1) % 3).AddDays(1 - dt.Day);  //本季度初
 11 DateTime endQuarter = startQuarter.AddMonths(3).AddDays(-1);  //本季度末
 12
 13 DateTime startYear = new DateTime(dt.Year, 1, 1);  //本年年初
 14 DateTime endYear = new DateTime(dt.Year, 12, 31);  //本年年末
 15 至于昨天、明天、上周、上月、上季度、上年度等等,只要AddDays()、AddMonths()、AddYears()这几种方法组合一下就可以了。
 16
 17 C#中datetime的使用
 18 大家在做报表或查询的时候都会有给用户预设一些可选的日期范围
 19 //如本年度销售额、本季度利润、本月新增客户
 20 //C#里内置的DateTime基本上都可以实现这些功能,巧用DateTime会使你处理这些事来变轻松多了
 21 //今天
 22 DateTime.Now.Date.ToShortDateString();
 23 //昨天,就是今天的日期减一
 24 DateTime.Now.AddDays(-1).ToShortDateString();
 25 //明天,同理,加一
 26 DateTime.Now.AddDays(1).ToShortDateString();
 27 //本周(要知道本周的第一天就得先知道今天是星期几,从而得知本周的第一天就是几天前的那一天,要注意的是这里的每一周是从周日始至周六止
 28 DateTime.Now.AddDays(Convert.ToDouble((0 - Convert.ToInt16(DateTime.Now.DayOfWeek)))).ToShortDateString();
 29 DateTime.Now.AddDays(Convert.ToDouble((6 - Convert.ToInt16(DateTime.Now.DayOfWeek)))).ToShortDateString();
 30 //如果你还不明白,再看一下中文显示星期几的方法就应该懂了
 31 //由于DayOfWeek返回的是数字的星期几,我们要把它转换成汉字方便我们阅读,有些人可能会用switch来一个一个地对照,其实不用那么麻烦的
 32 string[] Day = new string[] { "星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六" };
 33 Day[Convert.ToInt16(DateTime.Now.DayOfWeek)];
 34
 35 //上周,同理,一个周是7天,上周就是本周再减去7天,下周也是一样
 36 DateTime.Now.AddDays(Convert.ToDouble((0 - Convert.ToInt16(DateTime.Now.DayOfWeek))) - 7).ToShortDateString();
 37 DateTime.Now.AddDays(Convert.ToDouble((6 - Convert.ToInt16(DateTime.Now.DayOfWeek))) - 7).ToShortDateString();
 38 //下周
 39 DateTime.Now.AddDays(Convert.ToDouble((0 - Convert.ToInt16(DateTime.Now.DayOfWeek))) + 7).ToShortDateString();
 40 DateTime.Now.AddDays(Convert.ToDouble((6 - Convert.ToInt16(DateTime.Now.DayOfWeek))) + 7).ToShortDateString();
 41 //本月,很多人都会说本月的第一天嘛肯定是1号,最后一天就是下个月一号再减一天。当然这是对的
 42 //一般的写法
 43 DateTime.Now.Year.ToString() + DateTime.Now.Month.ToString() + "1"; //第一天
 44 DateTime.Parse(DateTime.Now.Year.ToString() + DateTime.Now.Month.ToString() + "1").AddMonths(1).AddDays(-1).ToShortDateString();//最后一天
 45
 46 //巧用C#里ToString的字符格式化更简便
 47 DateTime.Now.ToString("yyyy-MM-01");
 48 DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(1).AddDays(-1).ToShortDateString();
 49
 50 //上个月,减去一个月份
 51 DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(-1).ToShortDateString();
 52 DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();
 53 //下个月,加去一个月份
 54 DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(1).ToShortDateString();
 55 DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(2).AddDays(-1).ToShortDateString();
 56 //7天后
 57 DateTime.Now.Date.ToShortDateString();
 58 DateTime.Now.AddDays(7).ToShortDateString();
 59 //7天前
 60 DateTime.Now.AddDays(-7).ToShortDateString();
 61 DateTime.Now.Date.ToShortDateString();
 62
 63 //本年度,用ToString的字符格式化我们也很容易地算出本年度的第一天和最后一天
 64 DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).ToShortDateString();
 65 DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(1).AddDays(-1).ToShortDateString();
 66 //上年度,不用再解释了吧
 67 DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(-1).ToShortDateString();
 68 DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddDays(-1).ToShortDateString();
 69 //下年度
 70 DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(1).ToShortDateString();
 71 DateTime.Parse(DateTime.Now.ToString("yyyy-01-01")).AddYears(2).AddDays(-1).ToShortDateString();
 72
 73 //本季度,很多人都会觉得这里难点,需要写个长长的过程来判断。其实不用的,我们都知道一年四个季度,一个季度三个月
 74 //首先我们先把日期推到本季度第一个月,然后这个月的第一天就是本季度的第一天了
 75 DateTime.Now.AddMonths(0 - ((DateTime.Now.Month - 1) % 3)).ToString("yyyy-MM-01");
 76 //同理,本季度的最后一天就是下季度的第一天减一
 77 DateTime.Parse(DateTime.Now.AddMonths(3 - ((DateTime.Now.Month - 1) % 3)).ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();
 78 //下季度,相信你们都知道了。。。。收工
 79 DateTime.Now.AddMonths(3 - ((DateTime.Now.Month - 1) % 3)).ToString("yyyy-MM-01");
 80 DateTime.Parse(DateTime.Now.AddMonths(6 - ((DateTime.Now.Month - 1) % 3)).ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();
 81 //上季度
 82 DateTime.Now.AddMonths(-3 - ((DateTime.Now.Month - 1) % 3)).ToString("yyyy-MM-01");
 83 DateTime.Parse(DateTime.Now.AddMonths(0 - ((DateTime.Now.Month - 1) % 3)).ToString("yyyy-MM-01")).AddDays(-1).ToShortDateString();
 84
 85
 86 --------------------------------
 87
 88
 89 DateTime dt = DateTime.Now;
 90
 91 dt.ToString();//2005-11-5 13:21:25
 92 dt.ToFileTime().ToString();//127756416859912816
 93 dt.ToFileTimeUtc().ToString();//127756704859912816
 94 dt.ToLocalTime().ToString();//2005-11-5 21:21:25
 95 dt.ToLongDateString().ToString();//2005年11月5日
 96 dt.ToLongTimeString().ToString();//13:21:25
 97 dt.ToOADate().ToString();//38661.5565508218
 98 dt.ToShortDateString().ToString();//2005-11-5
 99 dt.ToShortTimeString().ToString();//13:21
100 dt.ToUniversalTime().ToString();//2005-11-5 5:21:25
101 dt.Year.ToString();//2005
102 dt.Date.ToString();//2005-11-5 0:00:00
103 dt.DayOfWeek.ToString();//Saturday
104 dt.DayOfYear.ToString();//309
105 dt.Hour.ToString();//13
106 dt.Millisecond.ToString();//441
107 dt.Minute.ToString();//30
108 dt.Month.ToString();//11
109 dt.Second.ToString();//28
110 dt.Ticks.ToString();//632667942284412864
111 dt.TimeOfDay.ToString();//13:30:28.4412864
112 dt.ToString();//2005-11-5 13:47:04
113 dt.AddYears(1).ToString();//2006-11-5 13:47:04
114 dt.AddDays(1.1).ToString();//2005-11-6 16:11:04
115 dt.AddHours(1.1).ToString();//2005-11-5 14:53:04
116 dt.AddMilliseconds(1.1).ToString();//2005-11-5 13:47:04
117 dt.AddMonths(1).ToString();//2005-12-5 13:47:04
118 dt.AddSeconds(1.1).ToString();//2005-11-5 13:47:05
119 dt.AddMinutes(1.1).ToString();//2005-11-5 13:48:10
120 dt.AddTicks(1000).ToString();//2005-11-5 13:47:04
121 dt.CompareTo(dt).ToString();//0
122 dt.Add(?).ToString();//问号为一个时间段
123 dt.Equals("2005-11-6 16:11:04").ToString();//False
124 dt.Equals(dt).ToString();//True
125 dt.GetHashCode().ToString();//1474088234
126 dt.GetType().ToString();//System.DateTime
127 dt.GetTypeCode().ToString();//DateTime
128
129 dt.GetDateTimeFormats(‘s‘)[0].ToString();//2005-11-05T14:06:25
130 dt.GetDateTimeFormats(‘t‘)[0].ToString();//14:06
131 dt.GetDateTimeFormats(‘y‘)[0].ToString();//2005年11月
132 dt.GetDateTimeFormats(‘D‘)[0].ToString();//2005年11月5日
133 dt.GetDateTimeFormats(‘D‘)[1].ToString();//2005 11 05
134 dt.GetDateTimeFormats(‘D‘)[2].ToString();//星期六 2005 11 05
135 dt.GetDateTimeFormats(‘D‘)[3].ToString();//星期六 2005年11月5日
136 dt.GetDateTimeFormats(‘M‘)[0].ToString();//11月5日
137 dt.GetDateTimeFormats(‘f‘)[0].ToString();//2005年11月5日 14:06
138 dt.GetDateTimeFormats(‘g‘)[0].ToString();//2005-11-5 14:06
139 dt.GetDateTimeFormats(‘r‘)[0].ToString();//Sat, 05 Nov 2005 14:06:25 GMT
140
141 string.Format("{0:d}",dt);//2005-11-5
142 string.Format("{0:D}",dt);//2005年11月5日
143 string.Format("{0:f}",dt);//2005年11月5日 14:23
144 string.Format("{0:F}",dt);//2005年11月5日 14:23:23
145 string.Format("{0:g}",dt);//2005-11-5 14:23
146 string.Format("{0:G}",dt);//2005-11-5 14:23:23
147 string.Format("{0:M}",dt);//11月5日
148 string.Format("{0:R}",dt);//Sat, 05 Nov 2005 14:23:23 GMT
149 string.Format("{0:s}",dt);//2005-11-05T14:23:23
150 string.Format("{0:t}",dt);//14:23
151 string.Format("{0:T}",dt);//14:23:23
152 string.Format("{0:u}",dt);//2005-11-05 14:23:23Z
153 string.Format("{0:U}",dt);//2005年11月5日 6:23:23
154 string.Format("{0:Y}",dt);//2005年11月
155 string.Format("{0}",dt);//2005-11-5 14:23:23
156 string.Format("{0:yyyyMMddHHmmssffff}",dt);
157
158
159 计算2个日期之间的天数差
160 -----------------------------------------------
161 DateTime dt1 = Convert.DateTime("2007-8-1");
162 DateTime dt2 = Convert.DateTime("2007-8-15");
163 TimeSpan span = dt2.Subtract(dt1);
164 int dayDiff = span.Days + 1;
165
166 计算某年某月的天数
167 -----------------------------------------------
168 int days = DateTime.DaysInMonth(2007, 8);
169 days = 31;
170
171 给日期增加一天、减少一天
172 -----------------------------------------------
173 DateTime dt =DateTime.Now;
174 dt.AddDays(1); //增加一天
175 dt.AddDays(-1);//减少一天
176 其它年份方法类似...
177
178 Oracle SQL里转换日期函数
179 -----------------------------------------------
180 to_date("2007-6-6",‘YYYY-MM-DD");
181 to_date("2007/6/6",‘yyyy/mm/dd");
182
183
184 如下一组数据,如何查找表里包含9月份的记录:
185 CGGC_STRATDATE CGGC_ENDDATE
186 =========================================
187 2007-8-4 2007-9-5
188 2007-9-5 2007-9-20
189 2007-9-22 2007-10-5
190
191 SELECT * FROM TABLE
192 (TO_DATE(‘2007/9/1‘,‘yyyy/mm/dd‘) BETWEEN CGGC_STRATDATE
193 AND CGGC_ENDDATE OR CGGC_STRATDATE >=TO_DATE(‘2007/9/1‘,‘yyyy/mm/dd‘)
194 AND CGGC_ENDDATE<=TO_DATE(‘2007/9/30‘,‘yyyy/mm/dd‘) "
195 OR TO_DATE(‘2007/9/30‘,‘yyyy/mm/dd‘) BETWEEN CGGC_STRATDATE
196 AND CGGC_ENDDATE) ORDER BY CGGC_STRATDATE ASC
时间: 2024-12-30 00:28:17

C#有关日期的使用方法的相关文章

MyEclipse 中自动安插作者、注释日期等快捷键方法

MyEclipse 中自动插入作者.注释日期等快捷键方法 MyEclipse 中自动插入作者.注释日期等de快捷键方法依次打开然后找到 Window -->Preferences->Java->Editor->Templates ,在这里new一个自己的插入注释的快捷方式名称,具体设置如下:Name处输入 remark  (任意你喜欢的名称) context处选 java 后边勾选Automatically insert复选框Description 这里可以任意输入描述Patter

Python中对时间日期的处理方法简单汇总

这篇文章主要介绍了Python实用日期时间处理方法汇总,本文讲解了获取当前datetime.获取当天date.获取明天/前N天.获取当天开始和结束时间(00:00:00 23:59:59).获取两个datetime的时间差.获取本周/本月/上月最后一天等实用方法 ,需要的朋友可以参考下 原地址:http://www.cnblogs.com/wenBlog/p/6097220.html 原则, 以datetime为中心, 起点或中转, 转化为目标对象, 涵盖了大多数业务场景中需要的日期转换处理 步

MySQL中判断日期间隔的方法

MySQL中查询一定时间间隔内的数据的方法比较常用,可以使用TO_DAYS.DATE_SUB等函数来实现. TO_DAYS函数的作用是返回指定日期从0年开始计算的天数. DATE_SUB函数的作用是通过指定日期减去指定间隔时间. 从而可以实现今天.昨天.最近7天(一周).最近30天(1个月).上个月等等查询方法.例子如下: 1.今天 SELECT * FROM t1 WHERE TO_DAYS(adddate) = TO_DAYS(CURDATE()); 2.昨天 SELECT * FROM t

验证日期格式的方法

判断日期格式的验证: 除IE浏览器外,可使用Date.parse()方法,该方法传入某个日期字符串,返回从1970-1-1 00:00:00到该日期对象的毫秒数,若无法识别则返回NaN IE浏览器不支持Date.parse()方法,其解决思路如下: 将字符串手动解析为数组: 使用Date的实例化,即new Date(a,b,c),返回date对象,若无法识别,则返回Invalid Date的对象: 调用对象的toString方法,返回结果值与'Invalid Date'相等,则为不合格日期格式,

js关于返回星期及日期格式的方法

,    js中使用Date()日期对象,星期返回值为0-6,不会直接返回星期几,所以要转成文字"星期X",思考了下我是这么写的: 1 var myd=new Date(); 2 var mydate=myd.getDay(); 3 switch(mydate){ 4 case 0: 5 document.write("星期日"); 6 break; 7 case 1: 8 document.write("星期一"); 9 break; 10 c

js时间日期的添加方法

需要的工具类:WdatePicker.js 添加方法,在所添加的页面添加上引入地址即可,如我的是: <script type="text/javascript"src="<%=basePath%>/js/v4/My97DatePicker/WdatePicker.js"></script> 在input文本框中的添加方法: <div class="fl ml20 mt8" style="_wid

Java中关于日期的处理方法

(1)Date *  Date: *  介绍是java.util包下的Date类,这个类是负责描述日期这类数据的. *  Date主要是描述当前时间毫秒值对象. *  它中的很多方法不利于国际化,已经被废弃. * *  Date是把当前的毫秒值封装成Date对象. *  如何把一个毫秒值转成Date对象 *  Date()它是把当前的时间点的毫秒值转成Date对象 *  Date(long date) 把我们指定的一个毫秒值转成Date对象 *  setTime(long time) 把当前的D

如何获取两个任意时间段内的所有日期(及其他处理日期时间的方法总结)

(1)用一下方法获取两个任意时间段内的所有日期,代码如下: #1.将字符串转换成datetime类型 def strtodatetime(datestr,format): return datetime.datetime.strptime(datestr,format) #2.时间转换成字符串,格式为2008-08-02 def datetostr(date): return str(date)[0:10] #3.两个日期相隔多少天,例:2008-10-03和2008-10-01是相隔两天 de

js日期/时间格式化方法

一.javascript Date format(日期格式化) 方法一: // 对Date的扩展,将 Date 转化为指定格式的String // 月(M).日(d).小时(h).分(m).秒(s).季度(q) 可以用 1-2 个占位符, // 年(y)可以用 1-4 个占位符,毫秒(S)只能用 1 个占位符(是 1-3 位的数字) // 例子: // (new Date()).Format("yyyy-MM-dd hh:mm:ss.S") ==> 2006-07-02 08:0