C# XML 反序列化为一张表中的 DataSet
Posted
技术标签:
【中文标题】C# XML 反序列化为一张表中的 DataSet【英文标题】:C# XML deserialization to DataSet within one table 【发布时间】:2020-02-18 11:30:34 【问题描述】:我正在制作一个自定义 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..."
提前感谢您提供任何相关提示^^
【问题讨论】:
你能分享你目前创建的解析代码吗? @Tim Rutter 当然,这比较简单:C# XmlSerializer xml = new XmlSerializer(obj.GetType()); // The obj variable is one of the 21 XSD schemes FileStream stream = new FileStream(ofd.FileName, FileMode.Open); /* * Here is a bit of code where I'm specifying which scheme should be used and then the xml.Deserialize() is used. */
您需要更明确地说明问题所在。
【参考方案1】:
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,
);
【讨论】:
感谢您的回答。所以我应该放弃 xsd.exe 生成的类并这样做吗?我很好奇,因为还有 20 个 XSD,它们比上面的例子复杂得多。 @netrag hm 也许您应该提供或附加一个指向示例 XML 文档的链接,它是 XSD 示例在 pastebin 上: XML 文件:pastebin.com/sv6Qxm4x XSD 文件:pastebin.com/NihPvQJ6 我想您已经尝试过类似DataSet ds = new DataSet(); ds.ReadXmlSchema(xsd); ds.ReadXml(xml); BindingSource bSource = new BindingSource(); bSource.DataSource = ds.Tables[1]; dataGridView1.DataSource = bSource;
的操作,但问题是缺少数据?
@netrag 问题是每个xsd:complexType
都会在数据集中生成一个单独的表,因此您可以使用代码编辑 xsd 或解析数据表。我不知道是什么别的不说。以上是关于C# XML 反序列化为一张表中的 DataSet的主要内容,如果未能解决你的问题,请参考以下文章
将xml反序列化为c#中的类时从XmlTextAttribute获取int值