检查Null元素的XML到LINQ

cga*_*ian 4 c# linq xml-parsing

我面临的情况是使用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();
Run Code Online (Sandbox Code Playgroud)

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

或许我完全错了,这是一个更好的方法!

Jon*_*eet 6

一个简单的选择是使用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();
Run Code Online (Sandbox Code Playgroud)

(请注意,您的原始代码不会编译,因为Value是字符串而0是int ...)