Asp.net日期字符串格式化显示方法

转载 2007年10月09日 12:06:00
在使用Asp.net的过程中,我们经常需要对时间日期进行转换,达到不同的显示效果。默认格式为:2006-6-6 14:33:34 ,如果要换成成200606,06-2006,2006-6-6或更多的格式该怎么办呢?

  这里将要用到: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, 2006

  在这里列出了参数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)

  如此类推.

  下面列出一些Asp.net中具体的日期格式化用法:

  ============================================

  1.绑定时格式化日期方法:

<ASP:BOUNDCOLUMN DATAFIELD= "JoinTime " DATAFORMATSTRING= "{0:yyyy-MM-dd} " >  
<ITEMSTYLE WIDTH= "18% " > </ITEMSTYLE >  
</ASP:BOUNDCOLUMN >

  2.数据控件如DataGrid/DataList等的件格式化日期方法:

e.Item.Cell[0].Text = Convert.ToDateTime(e.Item.Cell[0].Text).ToShortDateString();

  3.用String类转换日期显示格式:

String.Format( "yyyy-MM-dd ",yourDateTime);

  4.用Convert方法转换日期显示格式:

Convert.ToDateTime("2005-8-23").ToString
  ("yyMMdd",System.Globalization.DateTimeFormatInfo.InvariantInfo); //支持繁体数据库

  5.直接用ToString方法转换日期显示格式:

DateTime.Now.ToString("yyyyMMddhhmmss");
  DateTime.Now.ToString("yyyy/MM/dd hh:mm:ss")

  6.只显示年月

DataBinder.Eval(Container.DataItem,"starttime","{0:yyyy-M}")

  7.显示时间所有部分,包括:年月日时分秒

<asp:BoundColumn DataField="收款时间" HeaderText="收款时间"  
DataFormatString="{0:yyyy-MM-dd HH24:mm:ss}">
  
</asp:BoundColumn>

  [ASP.NET] 如何在GridView中使用DataFromatString

  在我们从业务逻辑层获得数据实体时候,接下来的事情就是要绑定到控件中。数据实体中的一些字段可以直接绑定到界面中,但是有一些字段需要重新格式化格式。比如货币单位字段,需要显示货币符号和每隔三位显示分隔符;再比如日期字段,数据库中存放的是日期和时间,但是在界面上需要按照XXXX年XX月XX日的格式显示。这时候我们就用到了DataFormatString属性。

<asp:GridView ID="grvResult" runat="server" AutoGenerateColumns="False" Width="100%">
      <Columns>
          <asp:BoundField HeaderText="预定日期" DataField="OperationDate" DataFormatString="{0:yyyy-MM-dd}" HtmlEncode="False">
          </asp:BoundField>       
          <asp:BoundField HeaderText="订单总计" DataField="TotalRate" DataFormatString="{0:C}" HtmlEncode="False">
          </asp:BoundField>
      </Columns>
</asp:GridView>

  例如上面的代码展示了日期和货币两种绑定方式。DataFormatString中的{0}是固定的格式,这和String.Fromat(“{0}”, someString)中的{0}是一个用法,表示绑定上下文的参数索引编号。然后,在后面加入格式化字符串,具体的使用方法可以参考MSDN。

  这里需要注意以下几点

  1. 在GridView中的asp:BoundField使用DataFormatString必须设置属性HtmlEncode="False",否则不起作用。

  2. 如果需要使用日期类型的格式化字符串,必须数据实体中对应的字段也应该日起类型的。

  3. 格式化字符串C代表货币单位,需要绑定的数据类型应该是数字类型的。如果是字符串类型的不起作用,需要手动添加格式化字符串为DataFormatString="¥{0:C}"。


 

Asp.net日期字符串格式化显示方法

可以这样写: date.ToString("yyyy年MM月", DateTimeFormatInfo.InvariantInfo)   如此类推.   下面列出一些Asp.net中具体的日期格式化用...
  • liuwei1128
  • liuwei1128
  • 2014年03月14日 21:36
  • 821

Asp.net日期字符串格式化显示

我们经常会遇到对时间进行转换,达到不同的显示效果,默认格式为:2006-6-6 14:33:34  如果要换成成200606,06-2006,2006-6-6或更多的格式该怎么办呢? 这里将要用到...
  • lwq8992628351
  • lwq8992628351
  • 2013年04月28日 12:33
  • 258

asp.net 中日期的格式化显示的方法

GridView中Dataformatstring 格式化日期应注意的问题 1、HtmlEncode="False" 2、DataFormatString="{0:d}" C#格式化日期时间...
  • SpringFileld
  • SpringFileld
  • 2014年06月02日 16:11
  • 407

Oracle中的日期和字符串互相转换以及格式化

#Oracle中的日期和字符串互相转换以及格式化 TO_DATE格式(以时间:2007-11-02 13:45:25为例) Year: yy two digits 两位年...
  • Peter_Spt
  • Peter_Spt
  • 2015年11月06日 13:46
  • 990

js 日期与字符串互转 (网上没有的, 字符串转日期支持任意格式化字符串)

网上现有的字符串 转 Date, 都是指定的几个格式 我实现了一个任意格式的, 只需要传入格式字符串就行了, 这个你在网上找不到  网上现有的Date.prototype.format也有一个小b...
  • wm3418925
  • wm3418925
  • 2016年12月08日 16:50
  • 568

Oracle日期、字符串格式化函数,位数不足前面加0,一位数字显示两位,格式化数字为定长

格式化函数 函数 返回类型 描述 例子 to_char(timestamp, text) text 把时间戳转换成字串 to_char(current_timestamp, 'HH12:...
  • a1264716408
  • a1264716408
  • 2016年08月26日 11:41
  • 1160

Android 字符串转指定格式时间 日期处理 去掉月份或天多余的0 获取今天 昨天 明天等的日期和星期

都是些基础知识,不过偶java学的不咋样,记录下吧。 字符串转化成指定格式时间: //字符串转指定格式时间 public static String getMyDate(String str) ...
  • wblyuyang
  • wblyuyang
  • 2015年01月16日 10:30
  • 4735

java 日期格式化-- SimpleDateFormat 的使用。字符串转日期,日期转字符串

日期和时间格式由 日期和时间模式字符串 指定。在 日期和时间模式字符串 中,未加引号的字母 'A' 到 'Z' 和 'a' 到 'z' 被解释为模式字母,用来表示日期或时间字符串元素。文本可以使用单...
  • qq_27093465
  • qq_27093465
  • 2016年11月04日 14:38
  • 20646

C/C++时间获取及格式化输出汇总

时间的存储结构一般有四种,time_t、struct tm、struct timeval、struct timespec。
  • u010599509
  • u010599509
  • 2015年07月26日 23:19
  • 2917

C#日期和时间的格式化输出

对于日期和时间,有多种格式化字符串输出形式,如下表说明: 日期和时间格式字符串及其说明 格式字符串 说          明 d 一位数或两位数的天数 dd 两位数的天数,如果是一位数...
  • u011647810
  • u011647810
  • 2013年08月21日 15:53
  • 1271
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Asp.net日期字符串格式化显示方法
举报原因:
原因补充:

(最多只允许输入30个字)