2

我正在查看一个如下所示的 XML 文件:

<test>
   <vehiclenumber>123</vehiclenumber>
   <form>
     <form_id>1</form_id>
     <datafield>
         <fieldnumber>1</fieldnumber>
         <data>
            <datawords>
               <datatext1>1234</datatext1>
               <mc2>656865</mc2>
            </datawords>
         </data>
      </datafield>
   </form>
</test>

目前我有以下代码:

IEnumerable<XElement> elements = documentXDoc.Descendants("test");

            _fuelReceipts.AddRange(elements
                .Select(receipt => new Receipt()
                {
                    vehicle_number = receipt.Element("vehiclenumber") == null ? "" : receipt.Element("vehiclenumber").Value,
                    field = receipt.Descendants("datafield")
                    .Select(x => new Field()
                    {
                        field_number = x.Element("fieldnumber") == null ? "" : x.Element("fieldnumber").Value,
                        event_data = x.Descendants("data")
                        .Select(y => new FieldData()
                        {
                            event_data = y.Value
                        }).ToList()
                    }).ToList()
                }));
        }

这里的问题是,<data>我不知道有多少后代将在那里或他们将被称为什么。有没有办法在不知道这些信息的情况下单独解析这些信息?现在,我会得到类似 1234656865 的东西,而实际上我想要一个对象中的 1234 和同一对象中的单独对象中的 656865。

4

2 回答 2

1

我假设 XML 后代的名称是有意义的。此代码将它们放在字典中,因为它将它们提取到 Field 对象中。

void Main()
{
    string input = "<test><vehiclenumber>123</vehiclenumber><form><form_id>1</form_id><datafield>";
    input += "<fieldnumber>1</fieldnumber><data><datawords>";
    input += "<datatext1>1234</datatext1><mc2>656865</mc2>";
    input += "</datawords></data></datafield></form></test>";

    XDocument documentXDoc = XDocument.Parse(input);
    IEnumerable<XElement> elements = documentXDoc.Descendants("test");

    IEnumerable<Receipt> _fuelReceipts =  elements
        .Select(receipt => new Receipt()
        {
            vehicle_number = receipt.Element("vehiclenumber") == null ? "" : receipt.Element("vehiclenumber").Value,
            field = receipt.Descendants("datafield")
            .Select(x => new Field()
            {
                field_number = x.Element("fieldnumber") == null ? "" : x.Element("fieldnumber").Value,
                event_data = x.Elements("data").Descendants()
                    .Where(d => !d.HasElements)
                    .ToDictionary(d => d.Name.LocalName, d => d.Value)
            }).ToList()
        });
}

class Receipt {
    public string vehicle_number { get; set; }
    public List<Field> field { get; set; }
}

class Field {
    public string field_number { get; set; }
    public Dictionary<string, string> event_data { get; set; }
}
于 2012-04-09T15:16:25.310 回答
1

将您的内部“数据”选择更改为:

event_data = x.Descendants("data").Descendants().Where(d => !d.HasElements).Select(y => y.Value).ToList()

这将给出一个string包含两个元素的列表:1234 和 656865。您可以使用String.Join()以下方法轻松地将其连接到一个字符串:

event_data = String.Join(" ", x.Descendants("data").Descendants().Where(d => !d.HasElements).Select(y => y.Value).ToList())
于 2012-04-09T15:07:06.777 回答