如何将 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 数据类型字符串并返回?的主要内容,如果未能解决你的问题,请参考以下文章
如何识别列抛出 System.Data.SqlClient.SqlException? (将 datetime2 数据类型转换为 datetime 数据类型)
如何解决“将 varchar 数据类型转换为 datetime 数据类型导致值超出范围。”错误