我搜索StackOverFlow,我发现了一个非常接近我的问题。 How to search XML using LINQ-to_XML Query
使用以下xml结构:
<EnfocusReport>
<Report>
<PreflightResult errors="2" criticalfailures="0" noncriticalfailures="0" signoffs="0" fixes="12" warnings="0">
<PreflightResultEntry type="Check" level="error">
<PreflightResultEntryMessage xml:lang="en-US">
<Message>Media box width is 792 pt, should be equal to 612 pt, Media box height is 612 pt, should be equal to 792 pt (9x on pages 1-9)</Message>
….
</EnfocusReport>
</Report>
我需要找到属性 level =“error”的所有元素 PreflightResultEntry :
<PreflightResultEntry type="Check" level="error">
然后能够读取消息的元素 PreflightResultEntryMessage / Message :
<Message>Media box width is 792 pt, should be equal to 612 pt, Media box height is 612 pt, should be equal to 792 pt (9x on pages 1-9)</Message>
所以我把它修改为我认为正确的结构但是我的返回查询是空的(没有数据)。
我的代码是:
var result2 = from EnfocusReport in XDocument.Load(args[0]).Root.Elements("EnfocusReport")
from Report in EnfocusReport.Elements("Report")
from PreflightResultEntry in Report.Elements("PreflightResultEntry")
from PreflightResultEntryMessage in PreflightResultEntry.Elements("PreflightResultEntryMessage")
where PreflightResultEntry.Attributes("level").Equals("error")
select PreflightResultEntryMessage.Elements("Message");
foreach (var el in result2)
{
Console.WriteLine(el);
Console.ReadLine();
}
答案 0 :(得分:0)
以下是我的行为:
var messages = XDocument.Load(args[0])
.Descendants("PreflightResultEntryMessage")
.Where(x => x.Parent != null &&
x.Parent.Name == "PreflightResultEntry" &&
x.Parent.Attribute("level") != null &&
x.Parent.Attribute("level").Value == "error")
.Select(x => x.Element("Message").Value);