我正在尝试从XML获取数据。我所知道的是,当我试图找到的动物不在XML数据中时,我总是会收到错误。如图所示的一个例子。
这是以XML格式存储的数据:
<?xml version="1.0" encoding="utf-8" ?>
<Root>
<Animal value="Elephant" size="2" name="Bob">
<Action age="1" size="1">I am small</Action>
<Action age="2" size="1">I am growing up</Action>
<Action age="3" size="1">I'm 3 years old</Action>
<Action age="4" size="1">I'm BIG</Action>
</Animal>
</Root>
这是C#编码的一部分:
XmlDocument xDoc = new XmlDocument();
xDoc.Load("animals.xml");
string animal = "Elephant";
MessageBox.Show(Convert.ToString(xDoc.SelectSingleNode("/Root/Animal[@value='" + animal + "']")
.Attributes["name"].InnerText));
更改
时发生错误string animal = "Tiger";
如果数据不存在,如何解决错误?
答案 0 :(得分:3)
您可以使用Linq to Xml获取动物的名称(如果未找到动物,它将返回null
):
XDocument xdoc = XDocument.Load("animals.xml");
string animal = "Elephant";
var name = xdoc.Root.Elements()
.Where(a => (string)a.Attribute("value") == animal)
.Select(a => (string)a.Attribute("name"))
.FirstOrDefault();
此外,您只需检查是否找到了与您的值相匹配的动物,只有在匹配时才能获取名称:
var xpath = String.Format("Root/Animal[@value='{0}']", animal);
var animalElement = xdoc.XPathSelectElement(xpath);
if (animalElement != null)
MessageBox.Show((string)animalElement.Attribute("name"));
答案 1 :(得分:2)
您可以使用SelectNodes
代替XmlNodeList
,然后检查其节点数。如果计数为零,则说“未找到节点”;否则,抓取属性,然后打印它:
XmlDocument xDoc = new XmlDocument();
xDoc.Load("animals.xml");
string animal = "Tiger";
XmlNodeList theList = xDoc.SelectNodes("/Root/Animal[@value='" + animal + "']");
if (theList.Count == 1) {
MessageBox.Show(Convert.ToString(theList[0].Attributes["value"].InnerText));
} else if (theList.Count == 0) {
MessageBox.Show("No "+animal);
} else {
MessageBox.Show("Multiple "+animal+"s");
}
答案 2 :(得分:0)
像
这样的东西var animalNode = xDoc.SelectSingleNode("/Root/Animal[@value='" + animal + "']");
if (animalNode != null)
{
var valueAttr = animalNode.Attributes["value"];
if (valueAttr != null)
{
MessageBox.Show(valueAttr.InnerText); //.value ???
}
}