[英]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.