C#解析这种日期格式的正确方法是什么" Mon Oct 07 00:00:00 EDT 2013"?

时间:2014-12-25 13:16:27

标签: c# json datetime json-deserialization jsonserializer

我从服务器收到一条json消息,我正在尝试将其解析为C#对象。我using the RestSharp Deserializer。有一个字段未正确转换为日期时间:

此消息中字段的字符串值为:

"createDateTime":"Mon Oct 07 00:00:00 EDT 2013"

在我的对象上,我将其作为:

public DateTime? createDateTime { get; set; }

注意:这是一个可以为空的DateTime,因为该字段为空白

但是当我这样做时:

var deSerializer = new JsonDeserializer();
var response = client.Execute(request);
var responseObj = _deSerializer .Deserialize<Response>(response);
return responseObj;

我意识到根本原因是DateTime.Parse失败了。我尝试添加这个导致它使用

   DateTime.ParseExact()

  _deserializer.DateFormat = "ddd MMM dd HH:mm:ss zzz yyyy";

但我得到一个错误说明:

字符串未被识别为有效的DateTime。

所以这一切都归结为C#如何解析以这种格式出现的日期

   Mon Oct 07 00:00:00 EDT 2013

1 个答案:

答案 0 :(得分:0)

因为在我的情况下我并不关心时间,而且时区总是在美国东部时间,我写这篇文章是为了在短期内解决这个问题。

    private DateTime? ParseMe(string s)
    {
        var split = s.Split(new[] {' '},StringSplitOptions.RemoveEmptyEntries);

        var year = int.Parse(split[split.Count()-1]);
        var day = int.Parse(split[2]);
        var month = split[1];
        int monthInDigit = DateTime.ParseExact(month, "MMM", CultureInfo.InvariantCulture).Month;
        return new DateTime(year, monthInDigit, day);
    }