将字符串的JARray从JObject转换为c#中的字符串数组

时间:2018-10-19 09:02:28

标签: c# json json.net

我有一个JSON,并且其中一部分包含

之类的字符串值
 "parent_crumbs": [
    "Platforms",
    "STATS , EXPE , ESTAP",
    "Portal"
],

我使用下面的代码从JSON对象读取值

 JObject _task; //parse the JSON to JOBJECT first               
 string values=    (string)_task["parent_crumbs"].ToString();

这将返回带方括号和仅所有引号的字符串。

如何在C#中将其转换为字符串数组

我可以删除[和],然后在上拆分,但是当出现在中间的字符串项中时,整个假设都将破坏。从JArray读取到String Array的方法也可以使用

1 个答案:

答案 0 :(得分:0)

您没有发布完整的json字符串,因此我们假设它是这样的:

{
    "id": 123,
     "parent_crumbs": [
        "Platforms",
        "STATS , EXPE , ESTAP",
        "Portal"
    ]
}

您可以创建一个与该结构匹配的C#模型,如下所示:

public class Data
{
    [JsonProperty("id")]
    public int Id { get; set; }

    [JsonProperty("parent_crumbs")]
    public List<string> ParentCrumbs { get; set; }
}

然后将json字符串反序列化为Data类的实例:

string json = @"{
    ""id"": 123,
     ""parent_crumbs"": [
        ""Platforms"",
        ""STATS , EXPE , ESTAP"",
        ""Portal""
    ]
}";

Data data = JsonConvert.DeserializeObject<Data>(json);

foreach (string crumb in data.ParentCrumbs)
{
    Console.WriteLine(crumb);
}

编辑

您可以执行以下操作,而不是反序列化整个json字符串:

string json = @"{
    ""id"": 123,
     ""parent_crumbs"": [
        ""Platforms"",
        ""STATS , EXPE , ESTAP"",
        ""Portal""
    ]
}";

JObject data = JObject.Parse(json);
JToken crumbsToken = data.GetValue("parent_crumbs");
List<string> crumbs = JsonConvert.DeserializeObject<List<string>>(crumbsToken.ToString());

// alternative way to get the string values, as suggested by @BrianRogers
List<string> crumbs = crumbsToken.ToObject<List<string>>();