检查Null元素的XML到LINQ

我面临的情况是使用Linq将XML文档解析为对象。 在解析期间,我正在检查以确保在继续解析其值之前,Elements不为null。 无论如何要简化这个陈述吗?

var variable = (from x in xdoc.Descendants("Root") select new AccountingResponse { NetCharge = x.Element("Charges") != null && x.Element("Charges").Element("NetCharge") != null ? x.Element("Charges").Element("NetCharge").Value : "0", TotalCharge = x.Element("Charges") != null && x.Element("Charges").Element("TotalCharge") != null ? x.Element("Charges").Element("TotalCharge").Value : "0" }).SingleOrDefault(); 

总而言之,我不想继续检查每一行上是否存在节点。 我知道我可以在解析之前测试节点是否存在,但可能还有其他数据需要解析才能创建AccountingResponse,我想避免if语句一次只解析一部分XML。

或者也许我这样做完全错了,而且有更好的方法!

一个简单的选择是使用Elements而不是Element – 如果元素不存在,将返回零长度序列。 所以你可以使用:

 from x in xdoc.Descendants("Root") select new AccountingResponse { NetCharge = x.Elements("Charges") .Elements("NetCharge") .Select(y => (int) y) .FirstOrDefault(), TotalCharge = x.Elements("Charges") .Elements("TotalCharge") .Select(y => (int) y) .FirstOrDefault(), }).SingleOrDefault(); 

(请注意,您的原始代码无法编译,因为Value是一个字符串,而0是一个int …)

你可以替换

 x.Element("nodeName") != null : int.Parse(x.Element("nodeName").Value) : 0 

 (int)x.Element("nodeName") 

它适用于stringintdoubledecimalbooluintDateTimeNullable

在C#6.0中,您可以使用monadic Null-conditional运算符?. 在您的示例中应用它之后,它将如下所示:

 var variable = (from x in xdoc.Descendants("Root") select new { NetCharge = x.Element("Charges")?.Element("NetCharge")?.Value ?? "0", TotalCharge = x.Element("Charges")?.Element("TotalCharge")?.Value ?? "0" }).SingleOrDefault(); 

您可以在这里阅读更多部分标题为Null-conditional运算符。