本文介绍了C#XDocument如何使用Linq过滤元素的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我正在使用
从Memory Stream读取XMLXDocument doc = XDocument.Load(targetStream);
foreach (XElement element in doc.Root.Elements())
{
Console.WriteLine(element);
}
我的一个元素如下所示。我不确定为什么要将名称空间xmlns添加到每个元素。基本上,我想筛选SerialNo=01的所有‘Header’元素
<Header xmlns="LR/2020-21">
<CollectionDetails>
<Collection>ILR</Collection>
<Year>2021</Year>
<FilePreparationDate>2020-05-08</FilePreparationDate>
</CollectionDetails>
<Source>
<ProtectiveMarking>OFFICIAL-SENSITIVE-Personal</ProtectiveMarking>
<UKPRN>99999999</UKPRN>
<SoftwareSupplier>SupplierName</SoftwareSupplier>
<SoftwarePackage>SystemName</SoftwarePackage>
<Release>1</Release>
<SerialNo>01</SerialNo>
<DateTime>2020-05-08T09:14:05</DateTime>
<!-- This and the next element only appear in files generated by FIS -->
<ReferenceData>Version5.0, LARS 2018-08-01</ReferenceData>
<ComponentSetVersion>1</ComponentSetVersion>
</Source>
</Header>
甚至下面的代码也带来了空记录
IEnumerable<XElement> list1 =
from el in doc.Descendants("Header")
where (string)el.Attribute("xmlns") == "LR/2020-21"
select el;
有人能帮我这个忙吗?
谢谢
推荐答案
因此,如果要筛选命名空间,则需要为元素名称提供正确的命名空间。如下所示:
var ns = XNamespace.Get("LR/2020-21");
var headers = doc.Root
.Elements(ns + "Header")
.Where(e => (string)e.Element(ns + "Source").Element(ns + "SerialNo") == "01");
如果同一Header
元素中存在多个SerialNo
,则可以使用以下表达式。
var ns = XNamespace.Get("LR/2020-21")
var matchingHeaders = doc.Root
.Elements(ns + "Header")
.Where(header => header
.Elements(ns + "Source")
.Any(source => source
.Elements(ns + "SerialNo")
.Any(serialNo => (string)serialNo == "01")))
这篇关于C#XDocument如何使用Linq过滤元素的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!