C# XML 在一个 table 内反序列化到 DataSet
C# XML deserialization to DataSet within one table
我正在为 read/edit 一组 XML 文档 (21) 创建自定义 XML 解析器。
他们都有自己的 XSD 并且是有效的 XML 文档。 XSD 文件已使用 xsd.exe 工具转换为可序列化的 *.cs 类。
为了澄清,我可以成功读取 XML,但我无法正确读取子节点 attributes/value 因此它显示在 DataGridView 中(resourceUrl 节点中的属性 wPath,见下面的例子)
由于我没有足够的经验w/XML和连载,我不确定以下几点:
.NET 是否提供了一些内置功能来处理读取子节点 attributes/values,或者我应该手动读取它?
在下面的示例中,所有属性及其值都已成功加载到 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..."
提前感谢您的任何相关提示^^
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,
});
}
我正在为 read/edit 一组 XML 文档 (21) 创建自定义 XML 解析器。 他们都有自己的 XSD 并且是有效的 XML 文档。 XSD 文件已使用 xsd.exe 工具转换为可序列化的 *.cs 类。
为了澄清,我可以成功读取 XML,但我无法正确读取子节点 attributes/value 因此它显示在 DataGridView 中(resourceUrl 节点中的属性 wPath,见下面的例子)
由于我没有足够的经验w/XML和连载,我不确定以下几点: .NET 是否提供了一些内置功能来处理读取子节点 attributes/values,或者我应该手动读取它?
在下面的示例中,所有属性及其值都已成功加载到 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..."
提前感谢您的任何相关提示^^
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,
});
}