期转化一

为了达到不同的显示效果有时,我们需要对时间进行转化,默认格式为:2007-01-03 14:33:34 ,要转化为其他格式,要用到DateTime.ToString的方法(String, IFormatProvider),如下所示:

C#代码
  1. using System;
  2. using System.Globalization;
  3. String format="D";
  4. DateTime date=DataTime,Now;
  5. Response.Write(date.ToString(format, DateTimeFormatInfo.InvariantInfo));
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)

日期转化二

C#代码
  1. DateTime dt = DateTime.Now;
  2. Label1.Text = dt.ToString();//2005-11-5 13:21:25
  3. Label2.Text = dt.ToFileTime().ToString();//127756416859912816
  4. Label3.Text = dt.ToFileTimeUtc().ToString();//127756704859912816
  5. Label4.Text = dt.ToLocalTime().ToString();//2005-11-5 21:21:25
  6. Label5.Text = dt.ToLongDateString().ToString();//2005年11月5日
  7. Label6.Text = dt.ToLongTimeString().ToString();//13:21:25
  8. Label7.Text = dt.ToOADate().ToString();//38661.5565508218
  9. Label8.Text = dt.ToShortDateString().ToString();//2005-11-5
  10. Label9.Text = dt.ToShortTimeString().ToString();//13:21
  11. Label10.Text = dt.ToUniversalTime().ToString();//2005-11-5 5:21:25
  12. Label1.Text = dt.Year.ToString();//2005
  13. Label2.Text = dt.Date.ToString();//2005-11-5 0:00:00
  14. Label3.Text = dt.DayOfWeek.ToString();//Saturday
  15. Label4.Text = dt.DayOfYear.ToString();//309
  16. Label5.Text = dt.Hour.ToString();//13
  17. Label6.Text = dt.Millisecond.ToString();//441
  18. Label7.Text = dt.Minute.ToString();//30
  19. Label8.Text = dt.Month.ToString();//11
  20. Label9.Text = dt.Second.ToString();//28
  21. Label10.Text = dt.Ticks.ToString();//632667942284412864
  22. Label11.Text = dt.TimeOfDay.ToString();//13:30:28.4412864
  23. Label1.Text = dt.ToString();//2005-11-5 13:47:04
  24. Label2.Text = dt.AddYears(1).ToString();//2006-11-5 13:47:04
  25. Label3.Text = dt.AddDays(1.1).ToString();//2005-11-6 16:11:04
  26. Label4.Text = dt.AddHours(1.1).ToString();//2005-11-5 14:53:04
  27. Label5.Text = dt.AddMilliseconds(1.1).ToString();//2005-11-5 13:47:04
  28. Label6.Text = dt.AddMonths(1).ToString();//2005-12-5 13:47:04
  29. Label7.Text = dt.AddSeconds(1.1).ToString();//2005-11-5 13:47:05
  30. Label8.Text = dt.AddMinutes(1.1).ToString();//2005-11-5 13:48:10
  31. Label9.Text = dt.AddTicks(1000).ToString();//2005-11-5 13:47:04
  32. Label10.Text = dt.CompareTo(dt).ToString();//0
  33. Label11.Text = dt.Add(?).ToString();//问号为一个时间段
  34. Label1.Text = dt.Equals("2005-11-6 16:11:04").ToString();//False
  35. Label2.Text = dt.Equals(dt).ToString();//True
  36. Label3.Text = dt.GetHashCode().ToString();//1474088234
  37. Label4.Text = dt.GetType().ToString();//System.DateTime
  38. Label5.Text = dt.GetTypeCode().ToString();//DateTime
  39. Label1.Text = dt.GetDateTimeFormats('s')[0].ToString();//2005-11-05T14:06:25
  40. Label2.Text = dt.GetDateTimeFormats('t')[0].ToString();//14:06
  41. Label3.Text = dt.GetDateTimeFormats('y')[0].ToString();//2005年11月
  42. Label4.Text = dt.GetDateTimeFormats('D')[0].ToString();//2005年11月5日
  43. Label5.Text = dt.GetDateTimeFormats('D')[1].ToString();//2005 11 05
  44. Label6.Text = dt.GetDateTimeFormats('D')[2].ToString();//星期六 2005 11 05
  45. Label7.Text = dt.GetDateTimeFormats('D')[3].ToString();//星期六 2005年11月5日
  46. Label8.Text = dt.GetDateTimeFormats('M')[0].ToString();//11月5日
  47. Label9.Text = dt.GetDateTimeFormats('f')[0].ToString();//2005年11月5日 14:06
  48. Label10.Text = dt.GetDateTimeFormats('g')[0].ToString();//2005-11-5 14:06
  49. Label11.Text = dt.GetDateTimeFormats('r')[0].ToString();//Sat, 05 Nov 2005 14:06:25 GMT
  50. Label1.Text = string.Format("{0:d}",dt);//2005-11-5
  51. Label2.Text = string.Format("{0:D}",dt);//2005年11月5日
  52. Label3.Text = string.Format("{0:f}",dt);//2005年11月5日 14:23
  53. Label4.Text = string.Format("{0:F}",dt);//2005年11月5日 14:23:23
  54. Label5.Text = string.Format("{0:g}",dt);//2005-11-5 14:23
  55. Label6.Text = string.Format("{0:G}",dt);//2005-11-5 14:23:23
  56. Label7.Text = string.Format("{0:M}",dt);//11月5日
  57. Label8.Text = string.Format("{0:R}",dt);//Sat, 05 Nov 2005 14:23:23 GMT
  58. Label9.Text = string.Format("{0:s}",dt);//2005-11-05T14:23:23
  59. Label10.Text   string.Format("{0:t}",dt);//14:23
  60. Label11.Text = string.Format("{0:T}",dt);//14:23:23
  61. Label12.Text = string.Format("{0:u}",dt);//2005-11-05 14:23:23Z
  62. Label13.Text = string.Format("{0:U}",dt);//2005年11月5日 6:23:23
  63. Label14.Text = string.Format("{0:Y}",dt);//2005年11月
  64. Label15.Text = string.Format("{0}",dt);//2005-11-5 14:23:23
  65. Label16.Text = string.Format("{0:yyyyMMddHHmmssffff}",dt);
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:25Label1.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.4412864Label1.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();//DateTimeLabel1.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 GMTLabel1.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、比较时间大小的实验

C#代码
  1. string st1="12:13";
  2. string st2="14:14";
  3. DateTime dt1=Convert.ToDateTime(st1);
  4. DateTime dt2=Convert.ToDateTime(st2);
  5. DateTime dt3=DateTime.Now;
  6. if(DateTime.Compare(dt1,dt2)>0)
  7. msg.Text=st1+">"+st2;
  8. else
  9. msg.Text=st1+"<"+st2;
  10. msg.Text+="\r\n"+dt1.ToString();
  11. if(DateTime.Compare(dt1,dt3)>0)
  12. msg.Text+="\r\n"+st1+">"+dt3.ToString();
  13. else
  14. msg.Text+="\r\n"+st1+"<"+dt3.ToString();
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;elsemsg.Text=st1+"<"+st2;msg.Text+="\r\n"+dt1.ToString();if(DateTime.Compare(dt1,dt3)>0)msg.Text+="\r\n"+st1+">"+dt3.ToString();elsemsg.Text+="\r\n"+st1+"<"+dt3.ToString();

2、计算两个时间差值的函数,返回时间差的绝对值:

C#代码
  1. private string DateDiff(DateTime DateTime1,DateTime DateTime2)
  2. {
  3. string dateDiff=null;
  4. try
  5. {
  6. TimeSpan ts1=new   TimeSpan(DateTime1.Ticks);
  7. TimeSpan ts2=new   TimeSpan(DateTime2.Ticks);
  8. TimeSpan ts=ts1.Subtract(ts2).Duration();
  9. dateDiff=ts.Days.ToString()+"天"
  10. +ts.Hours.ToString()+"小时"
  11. +ts.Minutes.ToString()+"分钟"
  12. +ts.Seconds.ToString()+"秒";
  13. }
  14. catch
  15. {
  16. }
  17. return dateDiff;
  18. }
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的功能

C#代码
  1. TimeSpan ts=new TimeSpan(40,0,0,0);
  2. DateTime dt2=DateTime.Now.Subtract(ts);
  3. msg.Text=DateTime.Now.ToString()+"-"+ts.Days.ToString()+"天\r\n";
  4. msg.Text+=dt2.ToString();
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();

转载于:https://www.cnblogs.com/scgw/archive/2009/08/26/1554269.html

C#日期格式化,时间相关推荐

  1. java 获取日期格式化时间_java获取当前时间并格式化

    java获取当前时间并格式化 private static final DateTimeFormatter FORMAT_FOURTEEN = DateTimeFormatter.ofPattern( ...

  2. MySQL日期格式化

    日期取年.月.日 select year(time),month(time), DAY(time),TIME(time) from user where phone='xx' #分别取年.月.日.时间 ...

  3. Java格式化日期用斜杠_[java工具类01]__构建格式化输出日期和时间的工具类

    在之前的学习中,我写过一篇关于字符串格式化的,就主要设计到了时间以及日期的各种格式化显示的设置,其主要时通过String类的fomat()方法实现的. 我们可以通过使用不同的转换符来实现格式化显示不同 ...

  4. java向MySQL插入当前时间的四种方式和java时间日期格式化的几种方法(案例说明)...

    转载地址:http://www.devba.com/index.php/archives/4581.html java向MySQL插入当前时间的四种方式和java时间日期格式化的几种方法(案例说明); ...

  5. javascript时间格式format函数,js日期格式化函数

    我在之前有一篇文章,写的是"javascript时间戳函数",大家可以看一下,记录了js时间戳的转换,今天主要写的函数式日期格式化函数,我们有时候调用的new Date()不是格式 ...

  6. C语言如何返回格式化日期时间(格式化时间)?(将日期和时间以字符串格式输出)ctime()、asctime()、localtime()、strftime()

    文章目录 ctime()函数: asctime()函数 获取自定义格式化时间(有bug,当时间为个位数时,没有在前面自动补零) 改成函数接口形式(传入字符指针) 20220107 优化后(能自动补零) ...

  7. 【cmd】日期、时间格式化

    前言 win10 获取日期 cmd> echo %date% 2021/08/29 周日 PS:格式与操作系统设定有关. 获取时间 cmd> echo %time% 10:15:58.26 ...

  8. 错误异常处理 小数格式化,取证与四舍五入 random处理 日期与时间常用操作

    异常处理 文章目录 异常处理 语法错误 语义错误 逻辑错误 异常处理 finally try eccept finally raise 测试 unittest 测试组织代码 常用断言方法 是否正确 存 ...

  9. java规定日期格式输出_Java格式化输出日期百分比时间等

    Java格式化输出 Java的格式化输出等同于String.Format,与C有很大的相似,比如 System.out.printf("%8.2f", x); 在printf中,可 ...

  10. 日期格式化为yyyymmdd_你还在用SimpleDateFormat格式化时间嘛

    Jdk1.8之时间处理 该文章已经同步到Github:https://github.com/stackInk/makerstack 1. 传统时间处理的问题 1.1 多线程环境下的SimpleDate ...

最新文章

  1. 中国计算机学会CCF推荐国际学术会议和期刊目录-软件工程/系统软件/程序设计语言
  2. python求pai的近似值_Python实现蒙特卡洛模拟(第1部分)【个人翻译自Medium】
  3. 如何迁移 Flink 任务到实时计算
  4. 007--C++动态内存(数组)
  5. stm32编程入门_电子设计与单片机编程书籍资料推荐
  6. Python的Django框架中forms表单类的使用方法详解
  7. php开发工具 debug,php开发性能调试工具xdebug
  8. 项目怎么导入mui_Vue项目MUI的使用
  9. 透过“简书钻”来探究简书的商业模式转变
  10. CPU指令集科普:CISC指令集和RISC指令集
  11. groovy脚本一键360加固多渠道打包
  12. 如何修改照片的尺寸大小
  13. 数据科学 IPython 笔记本 7.2 数据整理
  14. 手机黑屏摄像app_手机黑屏摄像软件下载-手机黑屏摄像持续拍摄app1.3安卓版下载_骑士下载...
  15. 书中自有黄金屋系列5:读《正面管教》
  16. windows安装mmdetection
  17. python中怎样定位字符串中元素的位置_python查找字符串位置
  18. 【JAVA长虹键法】第五式 抽象工厂模式(23种设计模式)
  19. AE自带抠像插件解释
  20. Silverlight 2教程(四):Chiron.exe:Silverlight 2打包和动态语言部署工具

热门文章

  1. 复练-软考网规-两地三中心
  2. php字符串函数的运用,php中字符串比较函数使用方法
  3. java订单超时取消设计_PHP如何实现处理过期或者超时订单的,并还原库存
  4. angularjs上传文件到服务器,AngularJS:如何使用multipart表单实现简单的文件上传?...
  5. JVM内存模型与GC回收器
  6. 信安教程第二版-第22章网站安全需求分析与安全保护工程
  7. Java基础---常用类之Math类 and Syetem类
  8. Asp.Net Core Web Api图片上传(一)集成MongoDB存储实例教程
  9. Oralce 日期操作
  10. Solve one floodlight install problem