C#XML反序列化到一个表中的数据集

C#XML反序列化到一个表中的数据集,c#,xml,xml-serialization,xml-deserialization,C#,Xml,Xml Serialization,Xml Deserialization,我正在制作一个自定义XML解析器来读取/编辑一组XML文档(21)。 它们都有自己的XSD,都是有效的XML文档。使用XSD.exe工具将XSD文件转换为可序列化的*.cs类 为了澄清,我可以成功地读取XML,但无法正确读取子节点属性/值,因此它显示在DataGridView中(resourceUrl节点中的属性wPath,请参见下面的示例) 由于我没有足够的使用XML和序列化的经验,我不确定以下几点: NET是否提供了一些内置功能来处理读取子节点属性/值的操作,还是我必须手动读取 在下面的示例

我正在制作一个自定义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>
提前感谢您提供的任何相关提示^^

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 url=doc.Root.Nodes().Cast();
列表产品=新列表();
foreach(url中的XElement url)
{
产品。添加(新产品()
{
ExternalProductId=url.Attribute(“ExternalProductId”).Value,
ProductSKU=url.Attribute(“ProductSKU”).Value,
Name=url.Attribute(“Name”).Value,
WPath=((XElement)url.FirstNode).Attribute(“WPath”).Value,
});
}  

你能分享你目前创建的解析代码吗?@Tim Rutter当然,它相对简单:
C#XmlSerializer xml=new XmlSerializer(obj.GetType());//obj变量是21个XSD方案之一FileStream stream=newfilestream(ofd.FileName,FileMode.Open);/**下面是一段代码,我指定应该使用哪个方案,然后使用xml.Deserialize()。*/你需要更明确地说明出了什么问题。谢谢你的回答。所以我应该放弃xsd.exe生成的类,这样做?我很好奇,因为还有20多个XSD比上面的例子复杂得多。@netrag hm也许您应该提供或附加一个指向示例XML文档的链接,它的XSD示例位于pastebin:XML文件:XSD文件:我想您已经尝试过做类似于
DataSet ds=new DataSet()的事情了;ReadXmlSchema(xsd);ReadXml(xml);BindingSource bSource=新的BindingSource();bSource.DataSource=ds.Tables[1];dataGridView1.DataSource=bSource
问题是缺少数据吗?@netrag问题是,每个
xsd:complexType
都会在数据集中生成一个单独的表,因此您可以编辑xsd或使用代码解析数据表。。我不知道还能说什么。
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,
    });
}