• asp.net日期显示


    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}"。

    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}"。

    一、数字的格式化:
    【<%#Container.DataItem("price")%>的结果是500.0000,怎样格式化为500.00?】
    <%#Container.DataItem("price","{0:¥#,##0.00}")%>
    int i=123456;
    string s=i.ToString("###,###.00");

    二、日期格式化:
    【aspx页面内:<%# DataBinder.Eval(Container.DataItem,"Company_Ureg_Date")%>
    显示为: 2004-8-11 19:44:28
    我只想要:2004-8-11 】
    <%# DataBinder.Eval(Container.DataItem,"Company_Ureg_Date","{0:yyyy-M-d}")%>
    【格式化日期】
    取出来,一般是object
    ((DateTime)objectFromDB).ToString("yyyy-MM-dd");
    如datetime.Text = ((DateTime)dr["DateTime"]).ToString("yyyy-MM-dd");

    在ASP.NET 2.0的Gridview中如果要在绑定列中显示比如日期格式等,如果用下面的方法是显示不了的。
    <asp :BoundField DataField="CreationDate"
    DataFormatString="{0:M-dd-yyyy}"
    HeaderText="CreationDate" />
    主要是由于htmlencode属性默认设置为true,已防止XSS攻击,安全起见而用的,所以,可以有以下两种方法解决

    1.将htmlencode设置为false即可
    <asp :GridView ID="GridView1" runat="server">
    <columns>
    <asp :BoundField DataField="CreationDate"
    DataFormatString="{0:M-dd-yyyy}"
    HtmlEncode="false"
    HeaderText="CreationDate" />
    </columns>
    </asp>
    2.另外的解决方法为,使用模版列
    <asp :GridView ID="GridView3" runat="server" >
    <columns>
    <asp :TemplateField HeaderText="CreationDate" >
    <edititemtemplate>
    <asp :Label ID="Label1" runat="server"
    Text='<%# Eval("CreationDate", "{0:M-dd-yyyy}") %>'>
    </asp>
    </edititemtemplate>
    <itemtemplate>
    <asp :Label ID="Label1" runat="server"
    Text=’<%# Bind("CreationDate", "{0:M-dd-yyyy}") %>'>
    </asp>
    </itemtemplate>
    </asp>
    </columns>
    </asp>

    附录-常用格式化公式:
    {0:C} 货币;
    {0:D4}由0填充的4个字符宽的字段中显示整数;
    {0:000.0}四舍五入小数点保留第几位有效数字;
    {0:N2}小数点保留2位有效数字;{0:N2}%   小数点保留2位有效数字加百分号;
    {0:D}长日期;{0:d}短日期;{0:yy-MM-dd}   例如07-3-25;;{0:yyyy-MM-dd} 例如2007-3-25

  • 相关阅读:
    Java IO: InputStreamReader和OutputStreamWriter
    Java IO: 序列化与ObjectInputStream、ObjectOutputStream
    Java IO: Buffered和Data
    [Codeforces Round #613 (Div. 2)]
    [算进] 巴士
    [算进] 小木棍
    [算进] 数据备份
    [算进] 双端队列 题解
    [算进] 蚯蚓 题解
    [算进] 赶牛入圈 题解
  • 原文地址:https://www.cnblogs.com/hateyoucode/p/1692410.html
Copyright © 2020-2023  润新知