从 C# 中的文件反序列化 Json
Deserialize Json from file in C#
我已经设法在不删除密钥路径的情况下找到了解决方案。
感谢大家的帮助,并指出问题,非常感谢! :)
将 Json 加载到一个字符串,将其反序列化为动态,运行 通过它进行 foreach,并添加到其中包含 ResFiles 的列表。
static void loadJson()
{
List<ResFile> fileList = new List<ResFile>();
string jsonString = File.ReadAllText(jsonPath);
dynamic files = JsonConvert.DeserializeObject(jsonString);
foreach (var f in files.objects)
fileList.Add(new ResFile(f.Name, f.Value.hash.ToString(), (int)f.Value.size.Value));
}
我正在尝试使用 Newtonsoft 的 Json 库在 C# 中反序列化一些 Json 文件。
这些文件以它的哈希命名,而不是真正的文件名,我想将它们重命名回正确的名称,所以像这样:
10a54fc66c8f479bb65c8d39c3b62265ac82e742 >> file_1.ext
Json 文件:
{
"files": {
"file_1.ext": {
"hash": "10a54fc66c8f479bb65c8d39c3b62265ac82e742",
"size": 8112
},
"file_2.ext": {
"hash": "14cfb2f24e7d91dbc22a2a0e3b880d9829320243",
"size": 7347
},
"file_3.ext": {
"hash": "bf7fadaf64945f6b31c803d086ac6a652aabef9b",
"size": 3838
},
"file_4.ext": {
"hash": "48f7e1bb098abd36b9760cca27b9d4391a23de26",
"size": 6905
}
}
}
我试过用这个反序列化:
static void loadJson()
{
using (StreamReader reader = new StreamReader(jsonPath))
{
string json = reader.ReadToEnd();
dynamic files = JsonConvert.DeserializeObject(json);
}
}
反序列化本身有效,但我不知道如何遍历它们。
我也试过这样做:
class ResFile
{
public string name;
public string hash;
public int size;
}
并以某种方式强制反序列化使用它,但它当然不起作用。
根据您的示例 json,您的 类 将是:
public class ResFile
{
public string hash { set; get; }
public int size { set; get; }
}
public class ResRoot
{
public Dictionary<string, ResFile> Files { set; get; }
}
你可以反序列化为
var res = JsonConvert.DeserializeObject<ResRoot>(File.ReadAllText(filename));
foreach(var f in res.Files)
{
Console.WriteLine("Name={0} Size={1}", f.Key, f.Value.size);
}
请遵循 C# 约定,不要将成员变量公开为 public 或 属性 名称以小写开头。为了使您的常规对象可反序列化,您可以使用 System.Runtime.Serialization DataContract 和 DataMember 属性。 DataContract 表示该类型的对象是可序列化的,DataMember 用于指定一个属性 的序列化名称。
class ResFile
{
[DataMember(Name = "name")]
public string Name { get; set; }
[DataMember(Name = "hash")]
public string Hash { get; set; }
[DataMember(Name = "size")]
public int Size { get; set; }
public ResFile () { }
}
[DataContract]
class ResFileCollection
{
[DataMember(Name ="files")]
public Dictionary<string, ResFile> Files { get; set; }
}
这里是反序列化:
string json = File.ReadAllText("data.json");
var files = JsonConvert.DeserializeObject<ResFileCollection>(json);
foreach(KeyValuePair<string, ResFile> f in files.Files)
{
Console.WriteLine("{0} {1} {2}", f.Key, f.Value.Name, f.Value.Hash);
}
序列化的 属性 名称也应该更短以获得更好的性能。一个例子:
[DataMember(Name="src")]
public string SourcePath { get; set; }
我已经设法在不删除密钥路径的情况下找到了解决方案。
感谢大家的帮助,并指出问题,非常感谢! :)
将 Json 加载到一个字符串,将其反序列化为动态,运行 通过它进行 foreach,并添加到其中包含 ResFiles 的列表。
static void loadJson()
{
List<ResFile> fileList = new List<ResFile>();
string jsonString = File.ReadAllText(jsonPath);
dynamic files = JsonConvert.DeserializeObject(jsonString);
foreach (var f in files.objects)
fileList.Add(new ResFile(f.Name, f.Value.hash.ToString(), (int)f.Value.size.Value));
}
我正在尝试使用 Newtonsoft 的 Json 库在 C# 中反序列化一些 Json 文件。
这些文件以它的哈希命名,而不是真正的文件名,我想将它们重命名回正确的名称,所以像这样:
10a54fc66c8f479bb65c8d39c3b62265ac82e742 >> file_1.ext
Json 文件:
{
"files": {
"file_1.ext": {
"hash": "10a54fc66c8f479bb65c8d39c3b62265ac82e742",
"size": 8112
},
"file_2.ext": {
"hash": "14cfb2f24e7d91dbc22a2a0e3b880d9829320243",
"size": 7347
},
"file_3.ext": {
"hash": "bf7fadaf64945f6b31c803d086ac6a652aabef9b",
"size": 3838
},
"file_4.ext": {
"hash": "48f7e1bb098abd36b9760cca27b9d4391a23de26",
"size": 6905
}
}
}
我试过用这个反序列化:
static void loadJson()
{
using (StreamReader reader = new StreamReader(jsonPath))
{
string json = reader.ReadToEnd();
dynamic files = JsonConvert.DeserializeObject(json);
}
}
反序列化本身有效,但我不知道如何遍历它们。
我也试过这样做:
class ResFile
{
public string name;
public string hash;
public int size;
}
并以某种方式强制反序列化使用它,但它当然不起作用。
根据您的示例 json,您的 类 将是:
public class ResFile
{
public string hash { set; get; }
public int size { set; get; }
}
public class ResRoot
{
public Dictionary<string, ResFile> Files { set; get; }
}
你可以反序列化为
var res = JsonConvert.DeserializeObject<ResRoot>(File.ReadAllText(filename));
foreach(var f in res.Files)
{
Console.WriteLine("Name={0} Size={1}", f.Key, f.Value.size);
}
请遵循 C# 约定,不要将成员变量公开为 public 或 属性 名称以小写开头。为了使您的常规对象可反序列化,您可以使用 System.Runtime.Serialization DataContract 和 DataMember 属性。 DataContract 表示该类型的对象是可序列化的,DataMember 用于指定一个属性 的序列化名称。
class ResFile
{
[DataMember(Name = "name")]
public string Name { get; set; }
[DataMember(Name = "hash")]
public string Hash { get; set; }
[DataMember(Name = "size")]
public int Size { get; set; }
public ResFile () { }
}
[DataContract]
class ResFileCollection
{
[DataMember(Name ="files")]
public Dictionary<string, ResFile> Files { get; set; }
}
这里是反序列化:
string json = File.ReadAllText("data.json");
var files = JsonConvert.DeserializeObject<ResFileCollection>(json);
foreach(KeyValuePair<string, ResFile> f in files.Files)
{
Console.WriteLine("{0} {1} {2}", f.Key, f.Value.Name, f.Value.Hash);
}
序列化的 属性 名称也应该更短以获得更好的性能。一个例子:
[DataMember(Name="src")]
public string SourcePath { get; set; }