将2015-06-01T02:31:00 + 0000转换为DateTime对象c#

时间:2015-06-01 03:31:58

标签: c# json date datetime utc

我正在撰写一个使用此网络服务的应用程序:

http://finance.yahoo.com/webservice/v1/symbols/allcurrencies/quote?format=json

正如您所见,JSON对象附带一个utc datetime字段。我想将此信息保存在一个简单的DateTime对象中,格式为“yyyy-MM-dd HH:mm:ss”。

这是我的代码:

 DateTime dateParsed = DateTime.Now;       
 DateTime.TryParseExact((string)resource.SelectToken("resource").SelectToken("fields")["utctime"], "yyyy'-'MM'-'dd'T'HH':'mm':'ssz", CultureInfo.InvariantCulture, System.Globalization.DateTimeStyles.AdjustToUniversal, out dateParsed);

我在0001年初始化了一个DateTime对象。

我做错了什么?

提前谢谢。

2 个答案:

答案 0 :(得分:5)

您应该使用the K custom format specifier(而不是z)。

string s = "2015-06-01T04:41:10+0000";

DateTime dt = DateTime.ParseExact(s, "yyyy-MM-dd'T'HH:mm:ssK",
                                  CultureInfo.InvariantCulture,
                                  DateTimeStyles.AdjustToUniversal);

它将读取+0000作为偏移量。然后,使用AdjustToUniversal样式,生成的DateTime ,具有DateTimeKind.Utc

此外,由于您正在阅读已知数据源,因此使用TryParseExact并没有什么好处。数据源中的格式是固定的,因此只需使用该格式的ParseExact即可。 Try...方法主要用于验证用户输入,或者源格式可能不同。

最后一点 - 如果您只使用JSON.net解析数据,则应自动识别该格式。您只需使用DateTimeDateTimeOffset属性,它就会毫无问题地解析它。

答案 1 :(得分:1)

您的Format-String中只有一个错误。这是一份工作样本:

using System;
using System.Globalization;

public class Program
{
    public static void Main()
    {
        DateTime dateParsed = DateTime.Now; 
        if ( DateTime.TryParseExact( "2015-06-01T02:31:00+0000", "yyyy-MM-ddThh:mm:ss+0000", CultureInfo.InvariantCulture, System.Globalization.DateTimeStyles.AdjustToUniversal, out dateParsed ) ) {
            Console.WriteLine(string.Format("Parsing done: {0:MM/dd/yyyy @ hh:mm}", dateParsed ) );
        } else {
            Console.WriteLine("No result");
        }
    }
}

注意:+0000是硬编码的,当您获得其他值时,您需要检测它们。如果api仅返回+0值,则可以将它们剪掉并在没有z的情况下工作。