c# - C#:XML 解析:在一个节点上对 XML 进行分组,然后在同一组下进行 subGroup
问题描述
<?xml version="1.0" encoding="UTF-8"?>
<Batch Id="" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<PurchaseOrders>
<PurchaseOrder id="xx267681">
<Header>
<AccountNumber>999</AccountNumber>
<ShipDate>2/10/2009</ShipDate>
</Header>
<PurchaseOrderDetails>
<Item>
<ItemNumber>yy235240</ItemNumber>
<Quantity>200</Quantity>
</Item>
<Item>
<ItemNumber>yy336820</ItemNumber>
<Quantity>3</Quantity>
</Item>
</PurchaseOrderDetails>
</PurchaseOrder>
<PurchaseOrder id="zz267456">
<Header>
<AccountNumber>123</AccountNumber>
<ShipDate>2/10/2009</ShipDate>
</Header>
<PurchaseOrderDetails>
<Item>
<ItemNumber>nn235240</ItemNumber>
<Quantity>200</Quantity>
</Item>
</PurchaseOrderDetails>
</PurchaseOrder>
</PurchaseOrders>
</Batch>
上面附的是我要解析的 XML 文件。我当前的 C# 代码查找 XML 文件中的所有项目并将其分配给 PO#。但是最近的 XML 文件我知道在同一个 XML 文件中可以有多个 PO#,因此我现在只需要找到与该 PO# 匹配的那些项目。所以在上面的例子中,带有 xx267681 的 PONumber 有 2 个项目,而第 2 个 PO 只有项目。
这是我到目前为止所尝试的。
try
{
ArrayList ItemsInFeed = new ArrayList();
XDocument xDoc = XDocument.Load(fileName);
foreach (var node in xDoc.Descendants("PurchaseOrder"))
{
poID = node.Attribute("id").Value;
}
foreach (var node in xDoc.Descendants("Item"))
{
Items itemRcd = new Items();
itemRcd.ItemNr = node.Descendants("ItemNumber")?.First().Value;
ItemsInFeed.Add(itemRcd);
}
if (ItemsInFeed.Count > 0)
{
// Do other logic based on the items linked to each PO#.
// Issue found : So far each XML file has one PO#, but latest XML file received has more than PO# and underlying items.
ItemsInFeed.Clear();
}
}
catch (Exception ex)
{
//Catch exception here
}
解决方案
尝试以下:
XDocument xDoc = XDocument.Load(fileName);
var results = xDoc.Descendants("PurchaseOrder").Select(x => new
{
poID = (string)x.Attribute("id"),
items = x.Descendants("Item").Select(y => new
{
itemNumber = (string)y.Element("ItemNumber"),
quantity = (int)y.Element("Quantity")
}).ToList()
}).ToList();
推荐阅读
- android - @MockK 或 mockk()
- linux - 如果条件通过,则从 mongo shell 退出 bash 脚本
- c# - ASP Net Core 和实体框架错误 - 在前一个操作完成之前在此上下文中启动了第二个操作
- c++ - 如何在 QT 中添加状态栏(不使用表单)并显示文本的长度和他的坐标(正在刷新)?
- azure-devops - 如何使用 azure DevOps API 为 GitHub Enterprise 存储库创建 azure DevOps 管道作为源
- oracle - 使用数据泵导出时无法重新映射数据
- r - 用于 plogis 的基本 R 代码的 Tidyverse 版本?
- azure-sql-database - 具有加入域的 Web 服务器的 Azure 托管 SQL 实例
- html - 我如何让这个菜单在滚动过去时粘在顶部?
- reactjs - antd嵌套表中如何使用树形数据?