XPATH解析xml文件

一、什么是XPATH

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

访问路径有

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

查找本地xml文件

将已写好xml文件保存在硬盘的一个位置,我将它保存在E盘
在这里插入图片描述

在这里插入图片描述

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)
在这里插入图片描述
然后将解析这个网站将手机号码里面的内容解析出来。

在这里插入图片描述

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)


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小满@

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值