更高效地筛选XDocument

4

我希望能够从XML文档中高效过滤出XML元素。

以联系人信息的XML文件为例:

<?xml version="1.0" encoding="ISO-8859-1"?>
<?xml-stylesheet type="text/xsl" href="asistentes.xslt"?>
<contactlist evento="Cena Navidad 2010" empresa="company">
  <contact type="1" id="1">
    <name>Name1</name>
    <email>xxxx@zzzz.es</email>
    <confirmado>SI</confirmado>
  </contact>
  <contact type="1" id="2">
    <name>Name2</name>
    <email>xxxxxxxxx@zzzze.es</email>
    <confirmado>Sin confirmar</confirmado>
  </contact>
</contaclist>

我目前用来从这个XML文档中筛选的代码:

using System; 
using System.Xml.Linq; 

class Test 
{ 
   static void Main() 
   { 
      string xml = @" the xml above"; 
      XDocument doc = XDocument.Parse(xml); 

      foreach (XElement element in doc.Descendants("contact")) {
         Console.WriteLine(element);
         var id = element.Attribute("id").Value;
         var valor = element.Descendants("confirmado").ToList()[0].Value;
         var email = element.Descendants("email").ToList()[0].Value;
         var name = element.Descendants("name").ToList()[0].Value;
         if (valor.ToString() == "SI") { }
      }
   } 
} 

如何最佳优化此代码以根据<confirmado>元素内容进行过滤?

2个回答

9
var doc = XDocument.Parse(xml); 

var query = from contact in doc.Root.Elements("contact")
            let confirmado = (string)contact.Element("confirmado")
            where confirmado == "SI"
            select new
            {
                Id    = (int)contact.Attribute("id"),
                Name  = (string)contact.Element("name"),
                Email = (string)contact.Element("email"),
                Valor = confirmado
            };

foreach (var contact in query)
{
    ...
}

注意事项:

  • doc.Root.Elements("contact") 只选择文档根目录中的 <contact> 元素,而不是在整个文档中搜索 <contact> 元素。

  • XElement.Element 方法 返回具有给定名称的第一个子元素。无需将子元素转换为列表并取第一个元素。

  • XElementXAttribute 类提供了广泛的方便的转换运算符


查询没有结果 :'( 问题可能是文件不完全是XML,而是带有<?xml、<?xml-stylesheet和节点contactlist的XSLT。 - Kiquenet

1
你可以使用LINQ:
foreach (XElement element in doc.Descendants("contact").Where(c => c.Element("confirmado").Value == "SI"))

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接