给定一个这样的XML结构:

<?xml version="1.0" encoding="ISO-8859-1"?>

<bookstore>

<book>
  <title lang="eng">Harry Potter</title>
  <price>29.99</price>
</book>

<book>
  <title lang="eng">Learning XML</title>
  <price>39.95</price>
</book>

</bookstore>

我怎么能得到的值的lang(其中lang是eng在书名),为第一个元素?


当前回答

下面是使用XPath和VTD-XML获取“lang”属性值的代码片段。

import com.ximpleware.*;
public class getAttrVal {
    public static void main(String s[]) throws VTDException{
        VTDGen vg = new VTDGen();
        if (!vg.parseFile("input.xml", false)){
            return ;
        }
        VTDNav vn = vg.getNav();
        AutoPilot ap = new AutoPilot(vn);
        ap.selectXPath("/bookstore/book/title/@lang");
        System.out.println(" lang's value is ===>"+ap.evalXPathToString());
    }
}

其他回答

你可以使用:

(//@lang)[1]

这意味着您将获得name等于“lang”的所有属性节点,并获得第一个。

下面是使用XPath和VTD-XML获取“lang”属性值的代码片段。

import com.ximpleware.*;
public class getAttrVal {
    public static void main(String s[]) throws VTDException{
        VTDGen vg = new VTDGen();
        if (!vg.parseFile("input.xml", false)){
            return ;
        }
        VTDNav vn = vg.getNav();
        AutoPilot ap = new AutoPilot(vn);
        ap.selectXPath("/bookstore/book/title/@lang");
        System.out.println(" lang's value is ===>"+ap.evalXPathToString());
    }
}

你也可以通过

string(//bookstore/book[1]/title/@lang)    
string(//bookstore/book[2]/title/@lang)

如果你使用XMLDOM和JavaScript,你可以编写类似的代码

var n1 = uXmlDoc.selectSingleNode("//bookstore/book[1]/title/@lang");

和n1。文本会给出值"eng"

你可以试试下面的xPath模式,

  XPathExpression expr = xPath.compile("/bookstore/book/title[@lang='eng']")

如果你正在使用PostgreSQL,这是获得它的正确方法。这只是一个假设,因为您有一个图书表TITLE和PRICE列填充数据。下面是问题

SELECT xpath('/bookstore/book/title/@lang', xmlforest(book.title AS title, book.price AS price), ARRAY[ARRAY[]::TEXT[]]) FROM book LIMIT 1;