开发者

Document - How to get a tag's value by its name?

I'm using Java's DOM parser to parse an XML file.

let's say I have the following XML

<?xml version="1.0"?>

<config>
    <dotcms开发者_如何学Python>
        <endPoint>ip</endPoint>
    </dotcms>
</config>

</xml>

I like to get the value of 'endPoint'. I can do it with the following code snippet. (assuming that I already parsed it with DocumentBuilder)

NodeList nodeList = this.doc.getElementByTagName("dotcms");
Node nValue = (Node) nodeList.item(0);
return nValue.getNodeValue();

Is it possible to get a value of a field by a field's name? Like....

Node nValue = nodeList.getByName("endPoint") something like this...?


You should use XPath for these sorts of tasks:

//endPoint/text()

or:

/config/dotcms/endPoint/text()

Of course Java has a built-in support for XPath:

XPath xpath = XPathFactory.newInstance().newXPath();
XPathExpression expr = xpath.compile("//endPoint/text()");
Object value = expr.evaluate(doc, XPathConstants.STRING);


You could also use jOOX, a jquery-like DOM wrapper, to write even less code:

// Using css-style selectors
String text1 = $(document).find("endPoint").text();

// Using XPath
String text2 = $(document).xpath("//endPoint").text();
0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜