0

对不起,我想问一下如何通过考虑标签名称及其属性来获取标签值。我使用 XML 在 lucene 上建立索引

这是 XML

 <?xml version="1.0" encoding="utf-8"?>
<Root xmlns:wb="http://www.worldbank.org">
  <data>
    <record>
      <field name="Country or Area" key="ARB">Arab World</field>
      <field name="Item" key="AG.AGR.TRAC.NO">Agricultural machinery, tractors</field>
      <field name="Year">1961</field>
      <field name="Value">73480</field>
    </record>
  </data>
</Root>

在早期项目中,我只使用如下来源获取标签值:

private String getTagValue(String tag, Element e) {
        NodeList nlList = e.getElementsByTagName(tag).item(0).getChildNodes();
        Node nValue = (Node) nlList.item(0);
        return nValue.getNodeValue();
    }

但是现在,我想考虑它的属性,所以我必须定义什么标签和属性才能获得正确的值。感谢你的回答

4

2 回答 2

1

为此目的使用 xpath 查询。首先创建一个类似这样的查询(例如获取具有一定值的字段节点):

myQuery = xpath.compile("//field[@value=\"1234\"]");

然后通过在 dom doc 上运行查询来填充节点集:

Object nodeSet = myQuery.evaluate(doc, XPathConstants.NODESET);
于 2013-01-13T03:14:26.447 回答
0

将 getTagValue 更改为

private static String getTagValue(NodeList list, String name) {
    for (int i = 0; i < list.getLength(); i++) {
        Element e = (Element) list.item(i);
        if (e.getAttribute("name").equals(name)) {
            return e.getTextContent();
        }
    }
    return null;
}

public static void main(String[] args) throws Exception {
    Document doc = DocumentBuilderFactory.newInstance().newDocumentBuilder()
            .parse(new File("1.xml"));
    NodeList fields = doc.getElementsByTagName("field");
    String country = getTagValue(fields, "Country or Area");
    String year = getTagValue(fields, "Year");
}
于 2013-01-13T05:04:40.303 回答