我是靠谱客的博主 满意热狗,最近开发中收集的这篇文章主要介绍XPath解析xml文件例子,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

package com.xpath.test;
import java.io.File;
import java.io.IOException;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.xpath.XPath;
import javax.xml.xpath.XPathConstants;
import javax.xml.xpath.XPathExpression;
import javax.xml.xpath.XPathExpressionException;
import javax.xml.xpath.XPathFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;
/**
 * @description 使用JDOM包中的XPath解析xml文件
 * @author Zhou-Jingxian
 *
 */
public class XPathSample {
 public static void main(String[] args) {
  try {
   DocumentBuilderFactory factory = DocumentBuilderFactory
     .newInstance();
   factory.setNamespaceAware(true);
   DocumentBuilder builder = factory.newDocumentBuilder();
   File file = new File(XPathSample.class.getResource("Book.xml").getFile());
   //"D:/J2EE/studyspace_6.0/XPathSample/books.xml"
   Document doc = (Document) builder.parse(file);
   XPathFactory xFactory = XPathFactory.newInstance();
   XPath xpath = xFactory.newXPath();
   String booknames = xpath.evaluate("/books/book[2]/name", doc);
   System.out.println(booknames);
   
   String expression = "";
//   expression = "//book[name='Thinking in Java']";
   expression = "//book";
   XPathExpression expr = xpath.compile(expression);
   Object result = expr.evaluate(doc, XPathConstants.NODESET);
   NodeList nodes = (NodeList) result;
   for (int i = 0; i < nodes.getLength(); i++) {
    Node node = nodes.item(i);
    System.out.println(node.getBaseURI() + "--"
      + node.getLocalName() + "--" + node.getNamespaceURI()
      + "--" + node.getNodeName() + "--" + node.getNodeType()
      + "--" + node.getPrefix() + "--"
      + node.getTextContent() + "--" + node.getAttributes()
      + "--" + node.getOwnerDocument() + "--"
      + node.getParentNode() + "--"
      + nodes.item(i).getNodeValue());
   }
  } catch (XPathExpressionException e) {
   e.printStackTrace();
  } catch (ParserConfigurationException e) {
   e.printStackTrace();
  } catch (SAXException e) {
   e.printStackTrace();
  } catch (IOException e) {
   e.printStackTrace();
  }
 }
}
Book.xml和XPathSample同目录
<?xml version="1.0" encoding="UTF-8"?>
<books>
	<book>
	    <name>Java Core II</name>
	    <price>119.00RMB</price>
	</book>
	
	<book>
	    <name>Effective Java</name>
	    <price>52.00RMB</price>
	</book>
	
	<book>
	    <name>Thinking in Java</name>
	    <price>108.00RMB</price>
	</book>
</books>
 

http://www.jdom.org/可以下载JDOM的最新版本,将压缩包中的jdom.jar及lib目录下的全部jar包加入到classpath就可以了。 (附件上传了一个1.1.1的jdom包)

 

更多XPath讲解请看http://www.ibm.com/developerworks/cn/xml/x-jdom/

最后

以上就是满意热狗为你收集整理的XPath解析xml文件例子的全部内容,希望文章能够帮你解决XPath解析xml文件例子所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(60)

评论列表共有 0 条评论

立即
投稿
返回
顶部