【问题标题】:Getting data out of deserialized object classes in C# using json.net使用 json.net 从 C# 中的反序列化对象类中获取数据
【发布时间】:2016-09-29 20:56:41
【问题描述】:

我自己创建的这个类:

    public class member
{
    public string account_name { get; set; }
    public long account_id { get; set; }
    public Rootobject[] rootobject { get; set; }
}

这是 VS 使用示例 JSON 答案自动为我创建的类:

public class Rootobject
{
    public string status { get; set; }
    public Meta meta { get; set; }
    public Data data { get; set; }
}
public class Meta
{
    public int count { get; set; }
}
public class Data
{
    public _507888780[] _507888780 { get; set; }
}
public class _507888780
{
    public All all { get; set; }
    public int tank_id { get; set; }
}
public class All
{
    public int spotted { get; set; }
    public int hits_percents { get; set; }
    public int wins { get; set; }
    ...
}

我使用的 API 服务器的一小部分 JSON 响应如下所示:

{
"status": "ok",
"meta": {
    "count": 1
},
"data": {
    "507888780": [
        {
            "all": {
                "spotted": 467,
                "hits_percents": 83,
                "wins": 281,
            },
            "tank_id": 2849
        },
        {
            "all": {
                "spotted": 224,
                "hits_percents": 63,
                "wins": 32,
            },
            "tank_id": 9473
        },
        }

}

这是我用来读出成员拥有的坦克(包括所有统计数据)的代码,其中 Request(string) 只是 http 请求。

private List<member> memberlist = new List<member>(100);
private void DoStuff()
{
memberlist = JsonConvert.DeserializeObject<List<member>>(result_member);
foreach (var member in memberlist)
        {
            string result_tank = Request("https://api.worldoftanks.eu/wot/tanks/stats/?application_id=" + application_id + "&account_id=" + member.account_id + "&tank_id=" + tanks + "&fields=all.battles%2C+all.wins%2C+all.damage_dealt%2C+all.frags%2C+all.hits_percents%2C+all.piercings%2C+all.shots%2C+all.spotted%2C+all.survived_battles%2C+all.tanking_factor");
            var Rootobject = JsonConvert.DeserializeObject<Rootobject>(result_tank);
            foreach (var tank in _507888780)
            {
                richTextBox1.Text += Rootobject.data._507888780[tank].tank_id + Rootobject.data._507888780[tank].all.spotted.ToString() + "...";
            }
        }
}

现在,我希望能够搜索所有不同的坦克,包括所有成员的统计数据。现在,我在要打印的行中遇到错误“Type Tank_Statistics._507888780 不能隐式转换为 int。”早些时候,我也收到了一个错误,缺少 IEnumerable,但我现在没有。 无论如何..我无法让它以某种方式工作..如果有人能够在这方面帮助我,那就太好了;)

【问题讨论】:

  • 请显示问题的minimal reproducible example,而不是构造对象或JSON的代码(两者都与您遇到的问题没有直接关系)。
  • 另外,请提交给.NETFiddle并在这里分享
  • dotnetfiddle.net/6Ix4pL 建议更改 @tym32167 现在我确实遇到了 JsonConvert.DeserializeObject 似乎没有正确填充类的问题。
  • 我猜那是因为 JSON 对象只是一个数字,但类是 _number。

标签: c# json implicit


【解决方案1】:

看来你应该替换这个

 richTextBox1.Text += Rootobject.data._507888780[tank].tank_id + Rootobject.data._507888780[tank].all.spotted.ToString() + "...";

到这里

richTextBox1.Text += tank.tank_id + tank.all.spotted.ToString() + "...";

【讨论】:

  • 谢谢,现在解决了这个问题;)现在我意识到反序列化并没有以某种方式填充 _507888780 类。尝试调用该类中的任何内容将始终返回 null。
猜你喜欢
  • 2017-05-26
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2011-08-16
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多