dom和xpath解析xml

发布时间:2020-07-06 12:47:48 作者:奔跑吧爽爽
来源:网络 阅读:994
import java.util.List;

import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.Node;
import org.dom4j.io.SAXReader;
import org.junit.Test;

/**
 * 解析xml
 * @author WangShuang
 *
 */
public class Demo {
    /**
     * 获取xml标签的文本内容和属性值
     * @param args
     */
    @Test
    public void run1() {
        try {
            //1.创建解析器对象
            SAXReader sax = new SAXReader();

            //2.解析xml文档
            Document document = sax.read("src/test.xml");

            //3.获得跟节点
            Element root = document.getRootElement();

            //4获取学生节点
            Element student = root.element("student");

            //5获取学生姓名节点
            Element name = student.element("name");
            System.out.println(name.getText());

            //获取学生属性编号的值
            Attribute attribute = name.attribute("id");
            System.out.println(attribute.getValue());

        } catch (DocumentException e) {
            e.printStackTrace();
        }
    }
    /**
     * xpath获取xml标签的文本内容和属性值
     * @param args
     */
    @Test
    public void run2() {
        try {
            // 1. 先创建解析器对象
            SAXReader sax = new SAXReader();
            //2 .解析xml文档
            Document document = sax.read("src/test.xml");
            // document是Node的子节点,能使用node节点对象的方法
            Node node = document.selectSingleNode("//name");
            // 获取学生姓名
            System.out.println(node.getText());
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
    /**
     * xpath获取xml标签的文本内容和属性值
     * @param args
     */
    @Test
    public void run3() {
        try {
            SAXReader sax = new SAXReader();
            Document document = sax.read("src/test.xml");
            List<Node> selectNodes = document.selectNodes("//name");
            for (Node node : selectNodes) {
                System.out.println(node.getText());
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

需要导入的jar包
dom和xpath解析xml

<?xml version="1.0" encoding="UTF-8"?>
<Person>
    <student>
        <name id="01">张三</name>
        <sex>男</sex>
    </student>
    <!-- <student>
        <name id="01">lili</name>
        <sex>nv</sex>
    </student> -->
</Person>
推荐阅读:
  1. DOM解析XML文件
  2. html使用xpath解析xml

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

解析 xml %d

上一篇:angularjs_xeditable整合typeahead完成智能提示

下一篇:spark调优(二):调节并行度

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》