- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
JsonConvert.DeserializeObject 和 JObject.Parse 有什么区别?据我所知,两者都带有一个字符串并且都在 Json.NET 库中。什么样的情况会让一个比另一个更方便,还是主要只是偏好?
作为引用,这是我使用两者来做完全相同的事情的示例 - 解析 Json 字符串并返回一个 Json 属性的列表。
public ActionResult ReadJson()
{
string countiesJson = "{'Everything':[{'county_name':null,'description':null,'feat_class':'Civil','feature_id':'36865',"
+"'fips_class':'H1','fips_county_cd':'1','full_county_name':null,'link_title':null,'url':'http://www.alachuacounty.us/','name':'Alachua County'"+ ",'primary_latitude':'29.7','primary_longitude':'-82.33','state_abbreviation':'FL','state_name':'Florida'},"+
"{'county_name':null,'description':null,"+ "'feat_class':'Civil','feature_id':'36866','fips_class':'H1','fips_county_cd':'3','full_county_name':null,'link_title':null,'url':'http://www.bakercountyfl.org/','name':'Baker County','primary_latitude':'30.33','primary_longitude':'-82.29','state_abbreviation':'FL','state_name':'Florida'}]}";
//Can use either JSONParseObject or JSONParseDynamic here
List<string> counties = JSONParseObject(countiesJson);
JSONParseDynamic(countiesJson);
return View(counties);
}
public List<string> JSONParseObject(string jsonText)
{
JObject jResults = JObject.Parse(jsonText);
List<string> counties = new List<string>();
foreach (var county in jResults["Everything"])
{
counties.Add((string)county["name"]);
}
return counties;
}
public List<string> JSONParseDynamic(string jsonText)
{
dynamic jResults = JsonConvert.DeserializeObject(jsonText);
List<string> counties = new List<string>();
foreach(var county in jResults.Everything)
{
counties.Add((string)county.name);
}
return counties;
}
最佳答案
LINQ-to-JSON API(JObject
、JToken
等)的存在是为了允许使用 JSON 而无需提前知道其结构。您可以使用 JToken.Parse
反序列化任何任意 JSON ,然后使用其他 JToken
检查和操作其内容方法。如果您只需要 JSON 中的一个或两个值(例如县名),LINQ-to-JSON 也能很好地工作。
JsonConvert.DeserializeObject
,另一方面,主要用于当你提前知道 JSON 的结构并且你想反序列化为强类型类时使用。例如,以下是如何将完整的县数据集从 JSON 获取到 County
的列表中。对象。
class Program
{
static void Main(string[] args)
{
string countiesJson = "{'Everything':[{'county_name':null,'description':null,'feat_class':'Civil','feature_id':'36865',"
+"'fips_class':'H1','fips_county_cd':'1','full_county_name':null,'link_title':null,'url':'http://www.alachuacounty.us/','name':'Alachua County'"+ ",'primary_latitude':'29.7','primary_longitude':'-82.33','state_abbreviation':'FL','state_name':'Florida'},"+
"{'county_name':null,'description':null,"+ "'feat_class':'Civil','feature_id':'36866','fips_class':'H1','fips_county_cd':'3','full_county_name':null,'link_title':null,'url':'http://www.bakercountyfl.org/','name':'Baker County','primary_latitude':'30.33','primary_longitude':'-82.29','state_abbreviation':'FL','state_name':'Florida'}]}";
foreach (County c in JsonParseCounties(countiesJson))
{
Console.WriteLine(string.Format("{0}, {1} ({2},{3})", c.name,
c.state_abbreviation, c.primary_latitude, c.primary_longitude));
}
}
public static List<County> JsonParseCounties(string jsonText)
{
return JsonConvert.DeserializeObject<RootObject>(jsonText).Counties;
}
}
public class RootObject
{
[JsonProperty("Everything")]
public List<County> Counties { get; set; }
}
public class County
{
public string county_name { get; set; }
public string description { get; set; }
public string feat_class { get; set; }
public string feature_id { get; set; }
public string fips_class { get; set; }
public string fips_county_cd { get; set; }
public string full_county_name { get; set; }
public string link_title { get; set; }
public string url { get; set; }
public string name { get; set; }
public string primary_latitude { get; set; }
public string primary_longitude { get; set; }
public string state_abbreviation { get; set; }
public string state_name { get; set; }
}
注意 Json.Net 使用给定 JsonConvert.DeserializeObject
的类型参数方法来确定要创建的对象类型。
当然,如果你在调用DeserializeObject
时没有指定类型,或者您使用 object
或 dynamic
, 那么 Json.Net 别无选择,只能反序列化为 JObject
. (您可以通过检查 JObject
自己看到您的动态变量实际上包含一个 jResults.GetType().FullName
。)所以在那种情况下,JsonConvert.DeserializeObject
之间没有太大区别。和 JToken.Parse
;两者都会给你相同的结果。
关于c# - JObject.Parse 与 JsonConvert.DeserializeObject,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23645034/
我有一个像这样的 json 结构: var json = { "report": {}, "expense": {}, "invoices": {}, "projects": {},
实际上,我正在处理从 Framework 3.5 中的旧 VB.NET 项目中的某个 API 获取的一些 JSON 数据 我被困在以下响应的处理中: { "data": { "89359"
我使用 json.net 比较流利,但我正在努力以一种直接的方式提取这个值。 我觉得 json.net 应该能够推断出我正在尝试做什么,这样我就不必为了获得我想要的东西而在整个过程中进行每一步。 下面
我有下面的 Java 代码,其中 Array 是一个自定义对象。 public native int pax_store_get_data_avail_info(DataAvailable[] sta
我尝试查找上述比较,但找不到答案。 因为有多种方法可以获取 JObject(或所有继承自 JToken 的子类型)例如: Method1 . JObject.FromObject(obj); Meth
我有一个变量 projectData,它包含存储在数据库中的有效 json 字符串。 完成以下操作后: JObject obj = new JObject(); obj = JObject.Parse
我有 2 个情景来说明这个问题。 场景一 using System; using Newtonsoft.Json.Linq; public class Program { public sta
我有一个像这样的 JObject: JObject grid = new JObject( new JProperty("myprop", "value
当我尝试解析一个大约有 200mb 的大型 json 文件时遇到问题。我正在用 Newtonsoft.Json 来做这件事。它给出了 OutOfMemory 异常。 这是我的代码: using (St
我正在尝试创建 JObject 的扩展类,它是不可变的。 如果我创建一个如下所示的类,它可以防止实际的 JObject 被修改吗? public class ImmutableJObejct: JOb
我试过了 JObject obj = new JObject(); obj["item1"] = new string[] {"a","b"}; 得到了 Cannot implicitly conv
我有一个 json 字符串,需要转换为 JObject。 例子: String result = ""{"totalSize":1,"done":true,"records":[{"attribute
这个问题在这里已经有了答案: Merge two Json.NET arrays by concatenating contained elements (3 个答案) 关闭 6 年前。 我有第一个
我正在尝试使用 JObject 创建一个像这样的 json 对象: { "input": { "webpage/url": "http://google.com/" }
我有一个使用 LINQ to JSON 构建的 JObject(我正在使用 Json.Net)(也由同一个库提供)。当我在 JObject 上调用 ToString() 方法时,它会将结果输出为格式化
我有一个包含以下内容的 XYZ.Json 文件。 { "ABC": "Account", "CDE": "Balance", "EFG": "Enquiry" } 我尝试使用以下代码从这个
我正在为 Cosmos DB(基于文档或 JSON 的 DB)创建数据库播种器。一些 C# 模型的属性 Config 是 JSON,所以我一直在使用这种类型的代码来设置该属性: Config = JO
概括: 借助美国教育部 API,我计划为计算机科学专业的毕业生创建一个大学列表和工资中位数。但是,许多学校都有空值,并且尝试删除空值会破坏代码,因为您无法在枚举时修改集合。 我的 denullifie
我有一个 JObject 项目,如下所示: { "part": { "values": ["engine","body","door"]
我有以下代码: JToken hours = jToken["hours"]; 它返回以下 JSON: { "monday": [ ["11:00", "21:30"]
我是一名优秀的程序员,十分优秀!