我找不到很多使用xerces-c 3.1评估XPath的例子。
给出以下示例XML输入:
<abc>
<def>AAA BBB CCC</def>
</abc>
我需要通过XPath“/ abc / def / text()[0]”检索“AAA BBB CCC”字符串。
以下代码有效:
XMLPlatformUtils::Initialize();
// create the DOM parser
XercesDOMParser *parser = new XercesDOMParser;
parser->setValidationScheme(XercesDOMParser::Val_Never);
parser->parse("test.xml");
// get the DOM representation
DOMDocument *doc = parser->getDocument();
// get the root element
DOMElement* root = doc->getDocumentElement();
// evaluate the xpath
DOMXPathResult* result=doc->evaluate(
XMLString::transcode("/abc/def"), // "/abc/def/text()[0]"
root,
NULL,
DOMXPathResult::ORDERED_NODE_SNAPSHOT_TYPE, //DOMXPathResult::ANY_UNORDERED_NODE_TYPE, //DOMXPathResult::STRING_TYPE,
NULL);
// look into the xpart evaluate result
result->snapshotItem(0);
std::cout<<StrX(result->getNodeValue()->getFirstChild()->getNodeValue())<<std::endl;;
XMLPlatformUtils::Terminate();
return 0;
但我真的很讨厌:
result->getNodeValue()->getFirstChild()->getNodeValue()
它是一个节点集而不是我想要的确切节点吗?
我尝试了其他格式的XPath,例如“/ abc / def / text()[0]”和“DOMXPathResult :: STRING_TYPE”。 xerces总是抛出异常。
我做错了什么?
答案 0 :(得分:3)
我不使用Xerces C ++进行编码,但它似乎实现了W3C DOM Level 3,因此我建议选择一个带有/abc/def
之类路径的元素节点,然后只需访问{{1获取元素的内容(例如result->getNodeValue()->getTextContent()
)。
据我了解DOM API,如果你想要一个字符串值,那么你需要使用类似AAA BBB CCC
的路径,然后string(/abc/def)
应该这样做(如果result->getStringValue()
方法请求任何类型或STRING_TYPE作为结果类型)。
如果您知道其他方法只对文档顺序中的第一个节点感兴趣,则可以使用evaluate
评估/abc/def
,然后访问FIRST_ORDERED_NODE_TYPE
。