[英]Retrieving XML value in C# from arbitary key path
我有一个项目,目前正在实现通过文档键内的任意/用户定义路径从XML文件读取值的支持。
例如,如果文档如下所示:
<information>
<machine>
<foo></foo>
<name>
test machine
</name>
<bar>spam</bar>
</machine>
</information>
那么用户可能想从information/machine
的name
键检索值。
有没有一种方法可以使用XDocument
/ XPath
来查找用户想要的值,而无需了解/编码文档的架构?
我最初的想法是通过使用XElement
项目的递归函数形式来处理文档,但是我觉得应该有一个更简单/更干净的解决方案,不需要我滚动自己的查找代码。
我也尝试了这些方法
var doc = XDocument.Load("C:\Path\to\XML\file.xml");
// Split the parent keys string
XElement elem = doc.Root.XPathSelectElement("path/to/key");
if (elem != null && elem.Attribute("wantedKeyName") != null)
replace = elem.Attribute("wantedKeyName").Value;
但elem
始终为空。 我假设我定义路径或使用XPathSelectElement的方式存在问题,但是我还没有解决。
static XmlNode SearchNode(XmlNodeList nodeList, string nodeName)
{
for (int i = 0; i < nodeList.Count; i++)
{
if (nodeList[i].Name == nodeName)
{
return nodeList[i];
}
if (nodeList[i].HasChildNodes)
{
XmlNode node = SearchNode(nodeList[i].ChildNodes, nodeName);
if (node != null)
{
return node;
}
}
}
return null;
}
static XmlNodeList SearchNodeByPath(XmlNodeList nodeList, string xPath)
{
for (int i = 0; i < nodeList.Count; i++)
{
var nodes = nodeList[i].SelectNodes(xPath);
if (nodes != null && nodes.Count > 0)
{
return nodes;
}
if (nodeList[i].HasChildNodes)
{
XmlNodeList innerNodes = SearchNodeByPath(nodeList[i].ChildNodes, xPath);
if (innerNodes != null && innerNodes.Count > 0)
{
return innerNodes;
}
}
}
return null;
}
这是使用方法:
var node = SearchNode(doc.ChildNodes, "compiler");
var node1 = SearchNodeByPath(doc.ChildNodes, "compilers/compiler");
我发现使用XPathSelectElement
解决方案是正确的方法,我只需要在path/to/key
字符串前加上//
。
我最终使用的以下代码将执行此操作,并去除了值外部的所有空白(如果值与开始标记不在同一行)。
// xml is a struct with the path to the parent node (path/to/key)
// and the key name to look up
// Split the parent keys string
XElement elem = doc.Root.XPathSelectElement("//" + xml.KeyPath);
if (elem != null && elem.Element(xml.Key) != null)
replace = elem.Element(xml.Key).Value.Trim();
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.