首页 > 解决方案 > C# XML 反序列化为一张表中的 DataSet

问题描述

我正在制作一个自定义 XML 解析器来读取/编辑一组 XML 文档 (21)。它们都有自己的 XSD 并且是有效的 XML 文档。使用 xsd.exe 工具将 XSD 文件转换为可序列化的 *.cs 类。

为了澄清起见,我可以成功读取 XML,但我无法正确读取子节点属性/值,因此它显示在 DataGridView 中(resourceUrl 节点中的属性 wPath,请参见下面的示例)

由于我没有足够的使用 XML 和序列化的经验,因此我不确定以下几点:.NET 是否提供了一些内置功能来处理读取子节点属性/值,或者我应该手动读取它?

在以下示例中,所有属性及其值都已成功加载到 DataSet/DataTable 中 - 除了 resourceUrl 节点 - 列在那里,但值只是类型的名称。

示例 XML:

<?xml version='1.0' encoding="utf-8" ?>
<c:product_resourceUrls xmlns:sql="urn:schemas-microsoft-com:xml-sql" xmlns:c="http://example.com/data/scl/product_resourceUrl">
  <y0:product_resourceUrl xmlns:y0="http://example.com/data/scl/product_resourceUrl" ExternalProductId="90AI8-3I" ProductSKU="90AI8-3I" Name="/images/path_to_product_img.jpg">
    <y0:resourceUrl WPath="/images/path_to_product_img.jpg"/>
  </y0:product_resourceUrl>
</c:product_resourceUrls>

DataTable 中的预期输出是这样的行(我不介意列顺序):

     WPath       | ExternalProductId | ProductSKU |      Name
"/images/p..."   |    "90AI8-3I"     |   90AI8-3I | "/images/p..."

提前感谢您的任何相关提示^^

标签: c#xmlxml-serializationxml-deserialization

解决方案


public class Product
{
    public string ExternalProductId { get; set; }
    public string ProductSKU { get; set; }
    public string Name { get; set; }
    public string WPath { get;  set; }
}

用法

var doc = XDocument.Load(xml);
var urls = doc.Root.Nodes().Cast<XElement>();

List<Product> products = new List<Product>();

foreach (XElement url in urls)
{
    products.Add(new Product()
    {
        ExternalProductId = url.Attribute("ExternalProductId").Value,
        ProductSKU = url.Attribute("ProductSKU").Value,
        Name = url.Attribute("Name").Value,
        WPath = ((XElement)url.FirstNode).Attribute("WPath").Value,
    });
}  

推荐阅读