我有一个这样的 JSON 字符串:
I have a JSON string like this:
{
"code": "GENDER",
"value": { "option": "ML" }
}
如果值为 "ML" 和 "Female",我想将 option 属性更新为 "Male" 如果值为 "FM".
I would like to update the option property to "Male" if the value is "ML" and "Female" if the value is "FM".
我已经到了这一点,但不确定如何继续:
I have got to this point, but am unsure how to proceed:
JArray contentobject = (JArray)JsonConvert.DeserializeObject(contentJSON);
JObject voicgObj = contentobject.Children().FirstOrDefault(ce => ce["code"].ToString() == "GENDER") as JObject;
JProperty voicgProp = voicgObj.Property("value");
我不知道如何访问 option,它是 value 的子项.
I don't know how to get to the option which is a child of value.
提前致谢.任何指针都会很棒.
Thanks in advance. Any pointers would be great.
可以通过属性作为键来访问对象:
You can access the object by using properties as keys:
JObject obj = JObject.Parse(json);
string gender = (string)obj["value"]["option"];
对于您的示例,请尝试:
For your example, try:
JObject obj = JObject.Parse(json);
var val = obj["value"];
string option = (string)val["option"];
if (option == "ML")
val["option"] = "Male";
if (option == "FM")
val["option"] = "Female";
string result = obj.ToString();
这篇关于如何使用 NewtonSoft 更新 JSON 对象的属性的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!
读取 XML 时忽略空格Ignore whitespace while reading XML(读取 XML 时忽略空格)
带有检查空元素的 XML 到 LINQXML to LINQ with Checking Null Elements(带有检查空元素的 XML 到 LINQ)
在 C# 中读取带有未闭合标签的 XMLReading XML with unclosed tags in C#(在 C# 中读取带有未闭合标签的 XML)
在 C# 中使用 Html 敏捷性解析表格、单元格Parsing tables, cells with Html agility in C#(在 C# 中使用 Html 敏捷性解析表格、单元格)
使用 LINQ 从 xml 中删除元素delete element from xml using LINQ(使用 LINQ 从 xml 中删除元素)
解析格式错误的 XMLParse malformed XML(解析格式错误的 XML)