【问题标题】:How do I convert DateTime .NET datatype to W3C XML DateTime data type string and back?如何将 DateTime .NET 数据类型转换为 W3C XML DateTime 数据类型字符串并返回?
【发布时间】:2011-08-06 08:09:49
【问题描述】:

我有一个System.DateTime 对象,我需要将其转换为以 W3C XML DateTime 格式 (yyyy-mm-ddThh:mm:ssZ) 存储该日期时间的字符串,然后能够将结果字符串转换回 @ 987654322@.

.NET 中是否为此做好了准备,还是我必须自己实现它?

【问题讨论】:

    标签: c# .net string types


    【解决方案1】:

    我认为JSON.net 可以处理它。 使用 IsoDateTimeConverter

    来自文档:

    public class LogEntry
    {
      public string Details { get; set; }
      public DateTime LogDate { get; set; }
    }
    
    [Test]
    public void WriteJsonDates()
    {
      LogEntry entry = new LogEntry
      {
        LogDate = new DateTime(2009, 2, 15, 0, 0, 0, DateTimeKind.Utc),
        Details = "Application started."
      };
    
      string defaultJson = JsonConvert.SerializeObject(entry);
      // {"Details":"Application started.","LogDate":"\/Date(1234656000000)\/"}
    
      string javascriptJson = JsonConvert.SerializeObject(entry, new JavaScriptDateTimeConverter());
      // {"Details":"Application started.","LogDate":new Date(1234656000000)}
    
      string isoJson = JsonConvert.SerializeObject(entry, new IsoDateTimeConverter());
      // {"Details":"Application started.","LogDate":"2009-02-15T00:00:00Z"}
    }
    

    【讨论】:

    • 如果他将它嵌入到 JSON 中是有意义的。否则不行。
    【解决方案2】:

    这将转换为您需要的字符串并将字符串解析回日期时间:

    var now = DateTime.Now;
    Console.WriteLine(now.ToUniversalTime().ToString());
    var nowString = now.ToUniversalTime().ToString("yyyy-MM-ddTHH:mm:ssZ");
    Console.WriteLine(nowString);
    
    var nowAgain = DateTime.ParseExact(nowString, "yyyy-MM-ddTHH:mm:ssZ", null);
    Console.WriteLine(nowAgain.ToUniversalTime().ToString());
    
    Console.ReadLine();
    

    【讨论】:

      【解决方案3】:

      我认为 W3C dateTime 的有效数字要多得多。 这是我使用的:

      // DateTime to W3C dateTime string
      string formatString= "yyyy-MM-ddTHH:mm:ss.fffffffzzz";
      dateTimeField.ToString(formatString) ;
      
      // W3C dateTime string to DateTime 
      System.Globalization.CultureInfo cInfo= new System.Globalization.CultureInfo("en-US", true);
      dateTimeField= System.DateTime.ParseExact(stringValue, formatString, cInfo);
      

      【讨论】:

        【解决方案4】:

        Xml 序列化为您服务。以下是如何操作的代码:-

        DateTime someDateTime = DateTime.Now.AddDays(5);
        System.Xml.Serialization.XmlSerializer ser = new System.Xml.Serialization.XmlSerializer(typeof(DateTime));
        System.IO.MemoryStream ms = new System.IO.MemoryStream();
        // converting to w3c xml
        ser.Serialize(ms, someDateTime);
        
        //**Edited**
        ms.Position = 0;
        //**Edited**
        
        System.IO.StreamReader sr = new System.IO.StreamReader(ms);
        string w3cxml = sr.ReadToEnd();
        
        sr.Close();
        ms.Close();
        
        // doing reverse
        System.IO.StringReader reader = new System.IO.StringReader(w3cxml);
        
        DateTime thatDateTime = (DateTime)ser.Deserialize(reader);
        
        reader.Close();
        

        【讨论】:

          【解决方案5】:

          如果您想要 W3C XML 格式的日期,请使用 .Net 的 W3C XML 格式化 API(自 v1.0 之前就已存在):

          var w3cStringFormat = XmlConvert.ToString(DateTime.Now);
          

          结果:

          2014-09-12T16:03:22.6833035+01:00

          然后再拿回来:

          var dateTime = XmlConvert.ToDateTime(w3cStringFormat);
          

          【讨论】:

          • XMLConvert 应该是第一个代码 sn-p 中的 XmlConvert。
          • 根据 MSDN,“XmlConvert.ToString(DateTime) 方法在 .NET Framework 2.0 版本中已过时,已被 XmlConvert.ToString(DateTime, XmlDateTimeSerializationMode) 方法取代。” — msdn.microsoft.com/en-us/library/zds88xsz(v=vs.110).aspx 不过,它仍然有效。
          • 我正在这样做:XmlConvert.ToString(DateTime.Now, XmlDateTimeSerializationMode.Local)。其他序列化方式在这里:msdn.microsoft.com/en-us/library/…
          猜你喜欢
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2010-11-12
          • 2020-12-06
          • 2023-03-06
          • 2013-04-24
          • 2020-10-27
          • 1970-01-01
          相关资源
          最近更新 更多