如何将 DateTime .NET 数据类型转换为 W3C XML DateTime 数据类型字符串并返回?

Posted

技术标签:

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

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

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

【问题讨论】:

【参考方案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/…

以上是关于如何将 DateTime .NET 数据类型转换为 W3C XML DateTime 数据类型字符串并返回?的主要内容,如果未能解决你的问题,请参考以下文章

如何将string 类型字段转换为datetime类型字段

如何识别列抛出 System.Data.SqlClient.SqlException? (将 datetime2 数据类型转换为 datetime 数据类型)

如何解决“将 varchar 数据类型转换为 datetime 数据类型导致值超出范围。”错误

将.NET DateTime 转换为 JSON [重复]

asp.net 无法将类型“System.DateTime”隐式转换为“string”

如何使用 linq 将 DATETIME 类型的列转换为字符串