博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
xPath用法
阅读量:5289 次
发布时间:2019-06-14

本文共 3363 字,大约阅读时间需要 11 分钟。

XPath基于XML的树状结构,提供在数据结构树中找寻节点的能力,下面是一小示例,需要的朋友可以参考下
 
 

XPath即为XML路径语言(XML Path Language),它是一种用来确定XML文档中某部分位置的语言。XPath基于XML的树状结构,提供在数据结构树中找寻节点的能力。起初 XPath 的提出的初衷是将其作为一个通用的、介于XPointer与XSL间的语法模型。但是 XPath 很快的被开发者采用来当作小型查询语言。

XPathTest.java

package com.hongyuan.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.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;public class XPathTest { public static void main(String[] args) throws ParserConfigurationException,   SAXException, IOException, XPathExpressionException {  // 解析文件,生成document对象  DocumentBuilder builder = DocumentBuilderFactory.newInstance()    .newDocumentBuilder();  Document document = builder.parse(new File("bookstore.xml"));  // 生成XPath对象  XPath xpath = XPathFactory.newInstance().newXPath();  // 获取节点值  String webTitle = (String) xpath.evaluate(    "/bookstore/book[@category='WEB']/title/text()", document,    XPathConstants.STRING);  System.out.println(webTitle);  System.out.println("===========================================================");  // 获取节点属性值  String webTitleLang = (String) xpath.evaluate(    "/bookstore/book[@category='WEB']/title/@lang", document,    XPathConstants.STRING);  System.out.println(webTitleLang);  System.out.println("===========================================================");  // 获取节点对象  Node bookWeb = (Node) xpath.evaluate(    "/bookstore/book[@category='WEB']", document,    XPathConstants.NODE);  System.out.println(bookWeb.getNodeName());  System.out.println("===========================================================");  // 获取节点集合  NodeList books = (NodeList) xpath.evaluate("/bookstore/book", document,    XPathConstants.NODESET);  for (int i = 0; i < books.getLength(); i++) {   Node book = books.item(i);   System.out.println(xpath.evaluate("@category", book,     XPathConstants.STRING));  }  System.out.println("==========================================================="); }} bookstore.xml复制代码代码如下:
Everyday Italian
Giada De Laurentiis
2005
30.00
Harry Potter
J K. Rowling
2005
29.99
Learning XML
Erik T. Ray
2003
39.95

  

InputStream inputStream = new ByteArrayInputStream(responseXML.trim().getBytes("UTF-8"));DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();DocumentBuilder db = dbf.newDocumentBuilder();Document doc = db.parse(inputStream);XPath xpath = XPathFactory.newInstance().newXPath();setResponseCode((xpath.evaluate("/InterBOSS/SvcCont/AdditionRsp/Status", doc)));String ordNum = (xpath.evaluate("/InterBOSS/SvcCont/AdditionRsp/OperSeqList/OperSeq", doc));setResponseContent((xpath.evaluate("/InterBOSS/SvcCont/AdditionRsp/ErrDesc", doc)));

 

运行效果

转载于:https://www.cnblogs.com/zengda/p/4765854.html

你可能感兴趣的文章
Path sum
查看>>
15.队列Queue的特点以及使用,优先级等
查看>>
checkbox,不选中传值
查看>>
JavaWeb学习笔记32--监听器(Listener)在开发中的应用
查看>>
6.1写sort函数对n个元素的整数数组n,按从小到大排序
查看>>
VirtualBox Host-Only 连接设置
查看>>
音频重采样
查看>>
【NOI OJ】一大波题正在飞来(ˉ▽ ̄~) 我才不是 Ctrl C + Ctrl V 的人呢
查看>>
BootStrap学习
查看>>
Unity又称Unity Application Block
查看>>
Hibernate的使用技巧②
查看>>
Git的安装与使用
查看>>
C# AutoResetEvent
查看>>
最近学到的前后端分离知识
查看>>
逆向工具整理
查看>>
应用安全-安全设备-Waf系列-软Waf-云锁
查看>>
安全团队博客整理
查看>>
安全运维 - Linux系统攻击回溯
查看>>
安全运维 - Linux系统维护
查看>>
安全运维 - Linux系统攻击应急响应
查看>>