我面临的情况是使用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。
或许我这样做完全错了,而且还有更好的办法!
答案 0 :(得分: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();
(请注意,您的原始代码无法编译,因为Value
是一个字符串,而0是一个int ...)
答案 1 :(得分:2)
您可以替换
x.Element("nodeName") != null : int.Parse(x.Element("nodeName").Value) : 0
带
(int)x.Element("nodeName")
适用于string
,int
,double
,decimal
,bool
,uint
,DateTime
和{{还有那些。
答案 2 :(得分:0)
在C#6.0中,您可以使用monadic Null条件运算符?.
在您的示例中应用它之后,它将如下所示:
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();
您可以在标题为空条件运算符的部分中阅读更多here。