帮助Linq进行Xml查询

时间:2011-04-28 11:08:41

标签: c# linq-to-xml

我在使用XDocument.Parse(myXmlString)生成的XDocument(通过检入调试器确认)中有以下xml

<Size>
    <row SizeId="239" Title="XXS" Quantity="20"/>
    <row SizeId="240" Title="XS" Quantity="15"/>
    <row SizeId="241" Title="S" Quantity="12"/>
    <row SizeId="242" Title="M" Quantity="18"/>
</Size>

我正在尝试将其转换为声明为:

的对象列表
public class SizeQuantityXml
{
    public int SizeId { get; set; }
    public string Title { get; set; }
    public int Quantity { get; set; }
}

但是当我这样做时,sizeQuantityXmlList只有第一个“行”:

List<SizeQuantityXml> sizeQuantityXmlList = 

(from x in xDocument.Descendants("Size")
 select new SizeQuantityXml() { SizeId = (int)x.Element("row").Attribute("SizeId"),
                                Title = (string)x.Element("row").Attribute("Title"),
                                Quantity = (int)x.Element("row").Attribute("Quantity") }
).ToList();

这是我的第一个Linq to XML尝试任何建议非常感谢: - )

1 个答案:

答案 0 :(得分:3)

您正在查询Size元素 - 您只有一个元素。您想要收集行代码:

var query = from row in xDocument.Element("Size").Descendants("row")
            select new SizeQuantityXml()
            { 
                SizeId = (int)row.Attribute("SizeId"),
                Title = (string)row.Attribute("Title"),
                Quantity = (int)row.Attribute("Quantity") 
            };

var sizeQuantityXmlList = query.ToList();

修改

如果您的XML与您发布的内容不同(例如,由更多父标记包装),则建议的解决方案将不起作用。尝试原先提出的Descendants("Size").Descendants("row")