首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在一个表中将C# XML反序列化为DataSet

在一个表中将C# XML反序列化为DataSet
EN

Stack Overflow用户
提问于 2019-10-22 18:24:17
回答 1查看 59关注 0票数 0

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

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

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

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

示例XML:

代码语言:javascript
复制
<?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中的预期输出是这样的行(我不关心列的顺序):

代码语言:javascript
复制
     WPath       | ExternalProductId | ProductSKU |      Name
"/images/p..."   |    "90AI8-3I"     |   90AI8-3I | "/images/p..."

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

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-10-22 18:48:54

代码语言:javascript
复制
public class Product
{
    public string ExternalProductId { get; set; }
    public string ProductSKU { get; set; }
    public string Name { get; set; }
    public string WPath { get;  set; }
}

用法

代码语言:javascript
复制
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,
    });
}  
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58502162

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档