C#日期时间格式化

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C#日期时间格式化相关的知识,希望对你有一定的参考价值。

日期转化一
技术分享
技术分享为了达到不同的显示效果有时,我们需要对时间进行转化,默认格式为:2007-01-03 14:33:34 ,要转化为其他格式,要用到DateTime.ToString的方法(String, IFormatProvider),如下所示:
技术分享
技术分享using System;
技术分享using System.Globalization;
技术分享String format="D";
技术分享DateTime date=DataTime,Now;
技术分享Response.Write(date.ToString(format, DateTimeFormatInfo.InvariantInfo));
技术分享
技术分享结果输出
技术分享Thursday, June 16, 2005
技术分享
技术分享参数format格式详细用法:
技术分享
技术分享格式字符 关联属性/说明 
技术分享d ShortDatePattern 
技术分享D LongDatePattern 
技术分享f 完整日期和时间(长日期和短时间) 
技术分享F FullDateTimePattern(长日期和长时间) 
技术分享g 常规(短日期和短时间) 
技术分享G 常规(短日期和长时间) 
技术分享m、M MonthDayPattern 
技术分享r、R RFC1123Pattern 
技术分享s 使用当地时间的 SortableDateTimePattern(基于 ISO 8601) 
技术分享t ShortTimePattern 
技术分享T LongTimePattern 
技术分享u UniversalSortableDateTimePattern 用于显示通用时间的格式 
技术分享U 使用通用时间的完整日期和时间(长日期和长时间) 
技术分享y、Y YearMonthPattern 
技术分享
技术分享下表列出了可被合并以构造自定义模式的模式。这些模式是区分大小写的;例如,识别“MM”,但不识别“mm”。如果自定义模式包含空白字符或用单引号括起来的字符,则输出字符串页也将包含这些字符。未定义为格式模式的一部分或未定义为格式字符的字符按其原义复制。
技术分享
技术分享格式模式 说明 
技术分享d 月中的某一天。一位数的日期没有前导零。 
技术分享dd 月中的某一天。一位数的日期有一个前导零。 
技术分享ddd 周中某天的缩写名称,在 AbbreviatedDayNames 中定义。 
技术分享dddd 周中某天的完整名称,在 DayNames 中定义。 
技术分享M 月份数字。一位数的月份没有前导零。 
技术分享MM 月份数字。一位数的月份有一个前导零。 
技术分享MMM 月份的缩写名称,在 AbbreviatedMonthNames 中定义。 
技术分享MMMM 月份的完整名称,在 MonthNames 中定义。 
技术分享y 不包含纪元的年份。如果不包含纪元的年份小于 10,则显示不具有前导零的年份。 
技术分享yy 不包含纪元的年份。如果不包含纪元的年份小于 10,则显示具有前导零的年份。 
技术分享yyyy 包括纪元的四位数的年份。 
技术分享gg 时期或纪元。如果要设置格式的日期不具有关联的时期或纪元字符串,则忽略该模式。 
技术分享h 12 小时制的小时。一位数的小时数没有前导零。 
技术分享hh 12 小时制的小时。一位数的小时数有前导零。 
技术分享H 24 小时制的小时。一位数的小时数没有前导零。 
技术分享HH 24 小时制的小时。一位数的小时数有前导零。 
技术分享m 分钟。一位数的分钟数没有前导零。 
技术分享mm 分钟。一位数的分钟数有一个前导零。 
技术分享s 秒。一位数的秒数没有前导零。 
技术分享ss 秒。一位数的秒数有一个前导零。 
技术分享f 秒的小数精度为一位。其余数字被截断。 
技术分享ff 秒的小数精度为两位。其余数字被截断。 
技术分享fff 秒的小数精度为三位。其余数字被截断。 
技术分享ffff 秒的小数精度为四位。其余数字被截断。 
技术分享fffff 秒的小数精度为五位。其余数字被截断。 
技术分享ffffff 秒的小数精度为六位。其余数字被截断。 
技术分享fffffff 秒的小数精度为七位。其余数字被截断。 
技术分享t 在 AMDesignator 或 PMDesignator 中定义的 AM/PM 指示项的第一个字符(如果存在)。 
技术分享tt 在 AMDesignator 或 PMDesignator 中定义的 AM/PM 指示项(如果存在)。 
技术分享z 时区偏移量(“+”或“-”后面仅跟小时)。一位数的小时数没有前导零。例如,太平洋标准时间是“-8”。 
技术分享zz 时区偏移量(“+”或“-”后面仅跟小时)。一位数的小时数有前导零。例如,太平洋标准时间是“-08”。 
技术分享zzz 完整时区偏移量(“+”或“-”后面跟有小时和分钟)。一位数的小时数和分钟数有前导零。例如,太平洋标准时间是“-08:00”。 
技术分享: 在 TimeSeparator 中定义的默认时间分隔符。 
技术分享/ 在 DateSeparator 中定义的默认日期分隔符。 
技术分享% c 其中 c 是格式模式(如果单独使用)。如果格式模式与原义字符或其他格式模式合并,则可以省略“%”字符。 
技术分享 c 其中 c 是任意字符。照原义显示字符。若要显示反斜杠字符,请使用“\”。 
技术分享
技术分享只有上面第二个表中列出的格式模式才能用于创建自定义模式;在第一个表中列出的标准格式字符不能用于创建自定义模式。自定义模式的长度至少为两个字符;例如, 
技术分享
技术分享DateTime.ToString( "d") 返回 DateTime 值;“d”是标准短日期模式。 
技术分享DateTime.ToString( "%d") 返回月中的某天;“%d”是自定义模式。 
技术分享DateTime.ToString( "d ") 返回后面跟有一个空白字符的月中的某天;“d”是自定义模式。 
技术分享
技术分享比较方便的是,上面的参数可以随意组合,并且不会出错,多试试,肯定会找到你要的时间格式
技术分享如要得到2005年06月 这样格式的时间
技术分享可以这样写:
技术分享date.ToString("yyyy年MM月", DateTimeFormatInfo.InvariantInfo)
技术分享
技术分享日期转化二
技术分享
技术分享DateTime dt = DateTime.Now;
技术分享Label1.Text = dt.ToString();//2005-11-5 13:21:25
技术分享Label2.Text = dt.ToFileTime().ToString();//127756416859912816
技术分享Label3.Text = dt.ToFileTimeUtc().ToString();//127756704859912816
技术分享Label4.Text = dt.ToLocalTime().ToString();//2005-11-5 21:21:25
技术分享Label5.Text = dt.ToLongDateString().ToString();//2005年11月5日
技术分享Label6.Text = dt.ToLongTimeString().ToString();//13:21:25
技术分享Label7.Text = dt.ToOADate().ToString();//38661.5565508218
技术分享Label8.Text = dt.ToShortDateString().ToString();//2005-11-5
技术分享Label9.Text = dt.ToShortTimeString().ToString();//13:21
技术分享Label10.Text = dt.ToUniversalTime().ToString();//2005-11-5 5:21:25
技术分享
技术分享Label1.Text = dt.Year.ToString();//2005
技术分享Label2.Text = dt.Date.ToString();//2005-11-5 0:00:00
技术分享Label3.Text = dt.DayOfWeek.ToString();//Saturday
技术分享Label4.Text = dt.DayOfYear.ToString();//309
技术分享Label5.Text = dt.Hour.ToString();//13
技术分享Label6.Text = dt.Millisecond.ToString();//441
技术分享Label7.Text = dt.Minute.ToString();//30
技术分享Label8.Text = dt.Month.ToString();//11
技术分享Label9.Text = dt.Second.ToString();//28
技术分享Label10.Text = dt.Ticks.ToString();//632667942284412864
技术分享Label11.Text = dt.TimeOfDay.ToString();//13:30:28.4412864
技术分享
技术分享Label1.Text = dt.ToString();//2005-11-5 13:47:04
技术分享Label2.Text = dt.AddYears(1).ToString();//2006-11-5 13:47:04
技术分享Label3.Text = dt.AddDays(1.1).ToString();//2005-11-6 16:11:04
技术分享Label4.Text = dt.AddHours(1.1).ToString();//2005-11-5 14:53:04
技术分享Label5.Text = dt.AddMilliseconds(1.1).ToString();//2005-11-5 13:47:04
技术分享Label6.Text = dt.AddMonths(1).ToString();//2005-12-5 13:47:04
技术分享Label7.Text = dt.AddSeconds(1.1).ToString();//2005-11-5 13:47:05
技术分享Label8.Text = dt.AddMinutes(1.1).ToString();//2005-11-5 13:48:10
技术分享Label9.Text = dt.AddTicks(1000).ToString();//2005-11-5 13:47:04
技术分享Label10.Text = dt.CompareTo(dt).ToString();//0
技术分享Label11.Text = dt.Add(?).ToString();//问号为一个时间段
技术分享
技术分享Label1.Text = dt.Equals("2005-11-6 16:11:04").ToString();//False
技术分享Label2.Text = dt.Equals(dt).ToString();//True
技术分享Label3.Text = dt.GetHashCode().ToString();//1474088234
技术分享Label4.Text = dt.GetType().ToString();//System.DateTime
技术分享Label5.Text = dt.GetTypeCode().ToString();//DateTime
技术分享
技术分享Label1.Text = dt.GetDateTimeFormats(‘s‘)[0].ToString();//2005-11-05T14:06:25
技术分享Label2.Text = dt.GetDateTimeFormats(‘t‘)[0].ToString();//14:06
技术分享Label3.Text = dt.GetDateTimeFormats(‘y‘)[0].ToString();//2005年11月
技术分享Label4.Text = dt.GetDateTimeFormats(‘D‘)[0].ToString();//2005年11月5日
技术分享Label5.Text = dt.GetDateTimeFormats(‘D‘)[1].ToString();//2005 11 05
技术分享Label6.Text = dt.GetDateTimeFormats(‘D‘)[2].ToString();//星期六 2005 11 05
技术分享Label7.Text = dt.GetDateTimeFormats(‘D‘)[3].ToString();//星期六 2005年11月5日
技术分享Label8.Text = dt.GetDateTimeFormats(‘M‘)[0].ToString();//11月5日
技术分享Label9.Text = dt.GetDateTimeFormats(‘f‘)[0].ToString();//2005年11月5日 14:06
技术分享Label10.Text = dt.GetDateTimeFormats(‘g‘)[0].ToString();//2005-11-5 14:06
技术分享Label11.Text = dt.GetDateTimeFormats(‘r‘)[0].ToString();//Sat, 05 Nov 2005 14:06:25 GMT
技术分享
技术分享Label1.Text = string.Format("{0:d}",dt);//2005-11-5
技术分享Label2.Text = string.Format("{0:D}",dt);//2005年11月5日
技术分享Label3.Text = string.Format("{0:f}",dt);//2005年11月5日 14:23
技术分享Label4.Text = string.Format("{0:F}",dt);//2005年11月5日 14:23:23
技术分享Label5.Text = string.Format("{0:g}",dt);//2005-11-5 14:23
技术分享Label6.Text = string.Format("{0:G}",dt);//2005-11-5 14:23:23
技术分享Label7.Text = string.Format("{0:M}",dt);//11月5日
技术分享Label8.Text = string.Format("{0:R}",dt);//Sat, 05 Nov 2005 14:23:23 GMT
技术分享Label9.Text = string.Format("{0:s}",dt);//2005-11-05T14:23:23
技术分享Label10.Text   string.Format("{0:t}",dt);//14:23
技术分享Label11.Text = string.Format("{0:T}",dt);//14:23:23
技术分享Label12.Text = string.Format("{0:u}",dt);//2005-11-05 14:23:23Z
技术分享Label13.Text = string.Format("{0:U}",dt);//2005年11月5日 6:23:23
技术分享Label14.Text = string.Format("{0:Y}",dt);//2005年11月
技术分享Label15.Text = string.Format("{0}",dt);//2005-11-5 14:23:23
技术分享Label16.Text = string.Format("{0:yyyyMMddHHmmssffff}",dt);  

C#比较两时间大小

1、比较时间大小的实验
    string st1="12:13";
    string st2="14:14";
    DateTime dt1=Convert.ToDateTime(st1);
    DateTime dt2=Convert.ToDateTime(st2);
    DateTime dt3=DateTime.Now;
    if(DateTime.Compare(dt1,dt2)>0)
     msg.Text=st1+">"+st2;
    else
     msg.Text=st1+"<"+st2;
    msg.Text+="\r\n"+dt1.ToString();
    if(DateTime.Compare(dt1,dt3)>0)
     msg.Text+="\r\n"+st1+">"+dt3.ToString();
    else
     msg.Text+="\r\n"+st1+"<"+dt3.ToString();
2、计算两个时间差值的函数,返回时间差的绝对值:
         private string DateDiff(DateTime DateTime1,DateTime DateTime2)
         {
             string dateDiff=null;
             try
             {
                 TimeSpan ts1=new   TimeSpan(DateTime1.Ticks);
                 TimeSpan ts2=new   TimeSpan(DateTime2.Ticks);
                 TimeSpan ts=ts1.Subtract(ts2).Duration();
                 dateDiff=ts.Days.ToString()+"天"
                         +ts.Hours.ToString()+"小时"
                         +ts.Minutes.ToString()+"分钟"
                         +ts.Seconds.ToString()+"秒";
             }
             catch
             {
             }
             return dateDiff;
         }
3、实现计算DateTime1-36天=DateTime2的功能
    TimeSpan ts=new TimeSpan(40,0,0,0);
    DateTime dt2=DateTime.Now.Subtract(ts);
    msg.Text=DateTime.Now.ToString()+"-"+ts.Days.ToString()+"天\r\n";
    msg.Text+=dt2.ToString();

以上是关于C#日期时间格式化的主要内容,如果未能解决你的问题,请参考以下文章

C#以“DDMMYYYY”格式解析日期?

返回一个文化格式化日期的数组 C# MVC3

C# 控制台日期输入

C#日期时间格式化

C#日期时间格式化

如何在 C# 中生成时间和日期并为 mysql 格式化?