1

我有一个与此类似的 XML 文档:

<document>
    <post>
      <author>Bill Smith</author>
      <subject>Test Article</subject>
      <dates>
          <uploaded>some date</uploaded>
          <published>some date</published>
      </dates>
      <price>
           <provider>Amazon</provider>
           <cost>1540</cost>
      </price>
      <price>
           <provider>WH Smith</provider>
           <cost>2640</cost>
      </price>
    </post>
    <post>
      <author>Bill Smith</author>
      <subject>Test Article</subject>
      <dates>
          <uploaded>some date</uploaded>
          <published>some date</published>
      </dates>
      <price>
           <provider>Amazon</provider>
           <cost>1540</cost>
      </price>
      <price>
           <provider>WH Smith</provider>
           <cost>2640</cost>
      </price>
    </post> 
</document>

我正在使用带有 .NET 4.5 的 XDocument。我知道还有其他方法可以用来排序。

我可以将每个帖子拉出并将其放入帖子模型中。但是,我想对价格元素进行排序并挑选出最低价格(以及提供者),以便我可以将其插入到我的 EF 数据库中。

任何帮助将不胜感激,我完全不知道从哪里开始。

4

4 回答 4

1

你可以试试这个:

        XDocument doc = XDocument.Load(@"Data.xml");
        var elements = doc.Root
            .Elements("post")
            .Select(post => new
            {
                Author = post.Element("author").Value,
                Subject = post.Element("subject").Value,
                Uploaded = Convert.ToDateTime(post.Element("dates").Element("uploaded").Value),
                Published = Convert.ToDateTime(post.Element("dates").Element("published").Value),
                Price = new
                {
                    P = post
                        .Elements("price")
                        .OrderByDescending(price => Convert.ToDecimal(price.Element("cost").Value))
                        .Select(o => new
                        {
                            Provider = o.Element("provider").Value,
                            Cost = Convert.ToDecimal(o.Element("cost").Value)
                        })
                        .First()
                }
            });

        var p = elements.First();
于 2013-03-01T20:18:08.367 回答
0

根据您提供的代码,看看是否可行:

var xmlDocumentElement = xDocument.Load("xmlData.xml").Root;

var posts = xmlDocumentElement.Elements("post").Select(post => new 
    {
    Author = post.Element("author").Value.ToString(),
    Subject = post.Element("subject").Value.ToString(),
    AvailableDate = DateTime.Parse(post.Descendants("dates").FirstOrDefault().Value),
    Price = GetPriceFromPriceXElement(post.Elements("price").Aggregate((prev, next) => 
            Decimal.Parse(prev.Element("cost").Value.ToString()) <= Decimal.Parse(next.Element("cost").Value.ToString()) ? prev : next ))
    }
    );

public Price GetPriceFromPriceXElement(XElement price)
{
   return new Price
    { 
        Provider = price.Element("provider").Value.ToString(),
        Cost = price.Element("cost").Value.ToString()
    };
}
于 2013-03-01T20:33:26.520 回答
0

试试这个。它应该工作。一旦你有数据,你可以按摩它。请注意NULL等。这只是围绕您的要求的基本想法。

 XDocument doc = XDocument.Load(@"XMLFile1.xml");
        var posts = doc.Root.Elements("post")
                   .Select(p =>
                            new
                            {
                               Author = p.Element("author").Value,
                               Price = p.Elements("price").OrderBy(a => decimal.Parse(a.Element("cost").Value)).First()
                     });

        foreach(var a in posts)
        {
            Console.WriteLine(a.Author + " " + a.Price);
        }
于 2013-03-01T21:05:59.663 回答
0

这是一个非常简单的尝试(实际上与 Ivan G 的答案非常相似):

var posts = from post in document.Root.Elements("post")
            select new
            {
                Author = post.Element("author").Value,
                Subject = post.Element("subject").Value,
                Uploaded = DateTime.Parse(post.Element("dates").Element("uploaded").Value),
                Published = DateTime.Parse(post.Element("dates").Element("published").Value),
                Price = (from price in post.Elements("price")
                         let cost = decimal.Parse(price.Element("cost").Value)
                         orderby cost
                         select new
                         {
                             Provider = price.Element("provider").Value,
                             Cost = cost
                         }).First()
            };

它适用于您提供给我们的示例数据(“某个日期”的日期除外)。

如果数据可能不完整或错误(即缺少/拼写错误的节点或错误的数据类型),我建议只取每个XElement而不是值:Author = post.Element("author")等。也许您希望允许没有上传或发布日期的帖子。这样您就可以稍后检查和/或转换/转换数据,并可能正确解决问题。

于 2013-03-02T00:23:20.967 回答