1

この JSON を取得します (XML として記述しました)。

<statuses>
    <metadata>
        <result_type>recent</result_type>
        <iso_language_code>tl</iso_language_code>
    </metadata>
    <created_at>Tue Jul 16 07:56:04 +0000 2013</created_at>
    <user>
        <id>1234</id>
        <id_str>4567</id_str>
        <name>Marco</name>      
    </user>
</statuses> 

(これはそれがどのように見えるかです):

{
    "statuses":[
    {
        "metadata":{
            "result_type":"recent",
            "iso_language_code":"tl"
        },
        "created_at":"Tue Jul 16 07:56:04 +0000 2013",
        "user":{
            "id":366581342,
            "id_str":"366581342",
            "name":"Marco Dalla Piazza"
        }
    }]
}       

created_atフィールドとname(の下)を抽出したいuser
JSON.NET ライブラリと LINQ を使用してそれを行うにはどうすればよいですか?

試した(名前について):

JObject xDoc = JObject.Parse(objectText);
var leo = xDoc.Descendants("user").Select(n => new
    name = n.Element("name").Value
{
}).First(); 

しかし、私はそのLINQメソッドを持っていないようです(LINQ to XMLで持っているように)。

4

1 に答える 1

2

このタスクにはLINQ to JSONを使用できるはずです。

JObject o = JObject.Parse(objectText);
var result =
    o["statuses"].Select(x => new { CreatedAt = (DateTime)x["created_at"],
                                    Name = (string)x["user"]["name"] });
于 2013-07-16T09:09:41.210 に答える