だから私はここでいくつかのxml解析を学ぼうとしていて、そのコツをつかんでいますが、何らかの理由で、各クエリの最後に「text()」を追加する必要があるようです。そうしないとnullになります値が返されました。この「text()」の終わりの機能は実際にはわかりませんが、必要ないことはわかっているので、なぜ省略できないのか疑問に思います。助けてください!これが私のコードです:
import org.w3c.dom.*;
import javax.xml.xpath.*;
import javax.xml.parsers.*;
import java.io.IOException;
import org.xml.sax.SAXException;
public class ParseClass
{
public static void main(String[] args)
throws ParserConfigurationException, SAXException,
IOException, XPathExpressionException
{
DocumentBuilderFactory domFactory = DocumentBuilderFactory.newInstance();
domFactory.setNamespaceAware(true);
DocumentBuilder builder = domFactory.newDocumentBuilder();
Document doc = builder.parse("C:\\Users\\Brandon\\Job\\XPath\\XPath_Sample_Stuff\\catalog.xml");
XPath xpath = XPathFactory.newInstance().newXPath();
XPathExpression expr = xpath.compile("/catalog/book[author='Thurman, Paula']/title/text()");
Object result = expr.evaluate(doc, XPathConstants.NODESET);
NodeList nodes = (NodeList) result;
for (int i = 0; i < nodes.getLength(); i++)
{
System.out.println(nodes.item(i).getNodeValue());
}
}
}
PS。気づかなかった場合に備えて。解析にXPathとDOMを使用しています。