温馨提示×

温馨提示×

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

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

dom和xpath解析xml

发布时间:2020-07-06 12:47:48 来源:网络 阅读:1061 作者:奔跑吧爽爽 栏目:开发技术
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>
向AI问一下细节

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

AI