簡體   English   中英

在linq到xml中使用過濾器列表

[英]Using a filter list with linq to xml

有沒有一種方法可以將字符串列表傳遞給linq to xml查詢,或者我需要分別指定每個過濾器? 我想計算與列表中的字符串同名的元素的數量。

這里的代碼顯然行不通,但可以讓您了解我要做什么:

XDocument doc = XDocument.Load(pathToXmlFile);

List<string> myList = new List<string> { "node1", "node2" };

int count = doc.Descendants().Where(x => x.Element(myList)).Count();

顯然,x.Element不能接受字符串列表,但是除了鍵入單個x.Element(“ node1”),x.Element(“ node2”)等之外,還有另一種方法嗎?

編輯:

我無法將其與隱式轉換為XName一起使用,所以這是我的方法:

int count = doc.Descendants().Where(x => myList.Any(n => x.Name.ToString() == n)).Count();

關鍵是Any方法。

這將按您期望的那樣工作:

int count = doc.Descendants().Where(x => myList.Any(n => x.Element(n))).Count();

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM