我必须解析一个大的Xml数据。以下是我的Xml数据的小例子
<Orders>
<PersonalData>
<Id>1</Id>
<WhoOrderedName>
<FirstName>abc</FirstName>
<MiddleName/>
<LastName>xyz</LastName>
</WhoOderedName>
</PersonalData>
.....
</Orders>
我必须验证每个元素是否存在以及值是否为null。现在我能够以这种方式实现它,但有没有更好的方法来验证元素存在和值非空。以下是我的代码
XDocument xml = XDocument.Parse(xmldata)
if (xml.Descendants("PersonalData").Elements("Id").Any())
{
if (!string.IsNullOrWhiteSpace(xml.Descendants("PersonalData").Elements("Id").First().Value))
OrdersXml += xml.Descendants("PersonalData").Elements("Id").First(); //adding the XElement to another xml string
else
Errordetails += "\r\n Id is Null";
}
else
Errordetails += "\r\n Id element is required";
答案 0 :(得分:1)
嗯,下面的方法只需要少一些代码,并且每次都不会从xml中查询元素(与您的方法不同):
XDocument xml = XDocument.Parse(xmldata)
var id = xml.Descendants("PersonalData").Elements("Id").FirstOrDefault();
if (id != null)
{
if (!string.IsNullOrWhiteSpace(id.Value))
OrdersXml += id;
else
Errordetails += "\r\n Id is Null";
}
else
Errordetails += "\r\n Id element is required";
答案 1 :(得分:0)
这就是我的看法,但您应该使用XSD架构。
foreach(var personalData in xdoc.Element("Orders").Descendants()){
if(personalData.Value == null){
//error?
}
}