1

我的 JSON 看起来像这样:

    {"2013" : [
        { "date":"2013-01-09 12:00:00","height":0 },
        { "date":"2013-01-19 12:00:00","height":3 },
        { "date":"2013-01-29 12:00:00","height":2 }],
    "2012" : [
        { "date":"2012-02-09 12:00:00","height":0 },
        { "date":"2012-02-19 12:00:00","height":4 },
        { "date":"2012-02-29 12:00:00","height":2 }],
    "2011" : [
        { "date":"2011-03-09 12:00:00","height":3 },
        { "date":"2011-03-19 12:00:00","height":8 },
        { "date":"2011-03-29 12:00:00","height":2 }]
   }

我想要做的是获取所有日期和高度,但我只能使用以下代码每年完成它:

    public class Report
    {
        public DateTime Date { get; set; }
        public int Height { get; set; }
    }

    JObject data = JObject.Parse(sr);
    var postTitles = from p in data["2013"]
                     select new Report
                     {
                         Date = DateTime.Parse((string)p["date"]),
                         Height = (int)p["height"]
                     };

我正在考虑使用 for 循环,但在 data[" "] 中尝试一个变量是行不通的。我也在考虑做 var postTitles += 声明,但也是不允许的。关于我应该如何解决这个问题的任何想法?我正在使用 JSON.NET,建议我每年上一堂课(即 2013、2012、2011 年),但我希望它们归于一个类,以便更轻松地操作数据。

4

2 回答 2

1

我对您使用的 LINQ 语法不是很好,但您想要做的是从许多列表中创建一个列表。因此,您想使用 LINQ 中的 SelectMany 映射操作。

var postTitles = data.Children()
        .SelectMany(subitems => subitems.First)
        .Select(dataOfYear =>
            new Report
                {
                    Date = DateTime.Parse((string)dataOfYear ["date"]),
                    Height = (int)dataOfYear ["height"]
                }
            );

如果您只想要每年的前 100 份报告,您可以这样做:

var postTitles = data.Children()
        .SelectMany(subitems => subitems.First)
        .Take(100)
        .Select(dataOfYear =>
            new Report
                {
                    Date = DateTime.Parse((string)dataOfYear ["date"]),
                    Height = (int)dataOfYear ["height"]
                }
            );

或者,如果您只想释放 UI 线程,您可以在后台线程中运行它:

var postTitles = await Task.Run(() => data.Children()
        .SelectMany(subitems => subitems.First)
        .Select(dataOfYear =>
            new Report
                {
                    Date = DateTime.Parse((string)dataOfYear ["date"]),
                    Height = (int)dataOfYear ["height"]
                }
            ));
于 2013-07-11T07:36:53.850 回答
0

我转过身,稍微扭曲了马克的回答,想出了这个:

var postTitles = data.Children() // Select array container properties, like "2013"
        .SelectMany(x => x.First) // Select each subitem from every array
        .Select(r => // Create a report for each item
            new Report
                {
                    Date = DateTime.Parse((string)r["date"]),
                    Height = (int)r["height"]
                }
            );

希望内联注释能够充分解释逻辑。

于 2013-07-11T09:31:39.897 回答