XPATH解析xml文件

XPATH解析xml文件

  • 一、什么是XPATH
  • 访问路径有
  • 查找本地xml文件
    • 2.解析网上xml文件

一、什么是XPATH

是一门在 XML 文档中查找信息的语言。XPath 用于在 XML 文档中通过元素属性进行导航。

访问路径有

路径表达式:
1. /   :  从根节点开始查找
2.  // :  重发起查找的的节点位置查找后节点 (使用最多)
3.  .  :  查找当前节点
4.  .. :  选择属性
5.  @  :  属性使用方法:
			[@ 属性名='值']
			[@ 属性名>'值']
			[@ 属性名<'值']
			[@ 属性名!='值']

查找本地xml文件

将已写好xml文件保存在硬盘的一个位置,我将它保存在E盘
XPATH解析xml文件_第1张图片

XPATH解析xml文件_第2张图片

package kkb.class_code.Leve4_核心类库.Demo8XML与JSON.XPATH解析;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;

import java.io.FileInputStream;
import java.io.IOException;
import java.util.List;

public class Demo1_XPATH解析本地xml文件 {
    public static void main(String[] args) throws IOException, DocumentException {
        //1、获取输入流-xml文件
        FileInputStream fis = new FileInputStream("e://Demo1.xml");
        //2、创建xml读取对象
        SAXReader sr = new SAXReader();
        //3、读取并得到文档对象
        Document doc = sr.read(fis);
        //4、通过文档获取根元素,selectNodesca查询多个
        List<Node> names = doc.selectNodes("//name");
        for(int i=0;i<names.size();i++){
            System.out.println(names.get(i).getName());
            System.out.println(names.get(i).getText());
        }
        System.out.println("----------------------");
        //5、selectSingleNode单查询
        Node n = doc.selectSingleNode("//book[@id='1001']//name");
        System.out.println(n.getName()+":"+n.getText());
        //关闭文件流
        fis.close();
    }
}

运行结果:

name
金苹果
name
银苹果
----------------------
name:金苹果

Process finished with exit code 0

2.解析网上xml文件

接下来我们来解析一个可以查询手机号码相关信息的网址。
地址为(http://apis.juhe.cn/mobile/get?%20phone=16670002013&dtype=xml&key=9f3923e8f87f1ea50ed4ec8c39cc9253)
XPATH解析xml文件_第3张图片
然后将解析这个网站将手机号码里面的内容解析出来。

XPATH解析xml文件_第4张图片

package kkb.class_code.Leve4_核心类库.Demo8XML与JSON.XPATH解析;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;

import java.io.IOException;
import java.io.InputStream;
import java.net.URL;
import java.net.URLConnection;

public class Demo2_XPATH解析网络xml文件 {
    public static void main(String[] args) throws IOException, DocumentException {
        //1、获取到xml资源的输入流
        String phone = "16670002013";
        URL url = new URL("http://apis.juhe.cn/mobile/get?%20phone=" + phone + "&dtype=xml&key=9f3923e8f87f1ea50ed4ec8c39cc9253");
        //打开链接
        URLConnection conn = url.openConnection();
        //拿下网址的输入流
        InputStream is = conn.getInputStream();
        //2、创建一盒XML读取对象
        SAXReader sr = new SAXReader();
        //3、通过读取对象 读取xml数据吗,并返回文档对象
        Document doc = sr.read(is);
        //4.XPATH寻找地址
        Node node = doc.selectSingleNode("//company");
        System.out.println("号码附属公司:" + node.getText());
    }


}

结果:

号码附属公司:联通

在上篇笔者写过通过获取元素解析xml文件,两者的区别不大,查询并没有说有提高,但是代码的操作会简单一点。


在这里插入图片描述

                                                                         IDEA中如何进行XML解析

                                                                         IDEA如何进行debug调试

                                                     一个非常方便的测试方法——JUnit单元测试(IDEA)


你可能感兴趣的:(Java,xml文件解析)