java dom4j 查找_Java使用dom4j查询xml元素

java dom4j 查找_Java使用dom4j查询xml元素1.Java使用dom4j查询xml元素:1.1book.xml文件如下:a1疯狂Java讲义(附光盘)李刚编著74.20java.jpg总结了几百个Java学员学习过程中的典型错误.]]>a2轻量级JavaEE企业应用实战李刚编著59.20ee.jpg本书主要介绍以Spring+Hibernate为基础的JavaEE应用.2.使用dom4j查询xml元素:创建一个TestPath类…

大家好,又见面了,我是你们的朋友全栈君。

1.Java使用dom4j查询xml元素:

1.1book.xml文件如下:

a1

疯狂Java讲义(附光盘)

李刚 编著

74.20

java.jpg

总结了几百个Java学员学习过程中的典型错误.]]>

a2

轻量级Java EE企业应用实战

李刚 编著

59.20

ee.jpg

本书主要介绍以Spring+Hibernate为基础的Java EE应用.

2.使用dom4j查询xml元素:创建一个TestPath类:

2.1先要导入dom4j 的包++++++++++++++++++++++++++++++++++++++++++++++++++++

import java.util.LinkedList; import java.util.List;

import org.dom4j.Document;

import org.dom4j.DocumentException;

import org.dom4j.Element;

import org.dom4j.io.SAXReader;

public class TestXPath {

public static void main(String[] args) throws DocumentException {

SAXReader reader = new SAXReader();

Document doc = reader.read(TestXPath.class.getResourceAsStream(“/book.xml”));

// 后面再增加一个方法,根据id查询。

// 传入doc的目的,是为了多次使用同一个Document

List list = getBookList(doc);

list.forEach(e -> {    System.out.println(e);   });

System.out.println(“========================================”);

// 再次使用同一个Document进行查询

Book b = getBookById(doc, “3”);

System.out.println(b);  }

private static Book getBookById(Document doc, String id) {

Element e = (Element) doc.selectSingleNode(“/books/book[id='” + id     + “‘]”);

Book b = toBook(e);

return b;  }

private static Book toBook(Element e) {

Book b = new Book();

// 获取子元素中,名为author的元素的内容

String author = e.elementText(“author”);

String id = e.elementText(“id”);

String image = e.elementText(“image”);

String name = e.elementText(“name”);

String price = e.elementText(“price”);

String remark = e.elementText(“remark”);

b.setAuthor(author);

b.setId(id);

b.setImage(image);

b.setName(name);

b.setPrice(price);

b.setRemark(remark);

return b;  }

private static List getBookList(Document doc) {

@SuppressWarnings(“unchecked”)

List nodeList = doc.selectNodes(“/books/book”);

// System.out.println(nodeList);

List result = new LinkedList<>();

nodeList.forEach(e -> {    Book b = toBook(e);    result.add(b);   });

return result;  } }

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/159418.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • python删除文本最后一行_用python删除文件中的最后一行

    python删除文本最后一行_用python删除文件中的最后一行如何用python删除文件的最后一行?输入文件示例:helloworldfoobar输出文件示例:helloworldfoo我创建了以下代码来查找文件中的行数,但是我不知道如何删除特定的行号。我是新来的python–所以如果有一个更简单的方法–请告诉我。try:file=open(“file”)exceptIOError:print”Failedtoreadfile.”cou…

    2022年5月18日
    45
  • LTE TDD与LTE FDD技术简介和比较

    LTE TDD与LTE FDD技术简介和比较摘要:UTRA的长期演进(LongTermEvolution,LTE)技术存在LTEFDD和LTETDD两大阵营,本文在比较分析TDD和FDD技术特点的基础上,对LTETDD(即TD-LTE)的特有技术进行了总结,并结合中国移动现有的网络部署和TDD频段资源情况,对LTETDD和LTEFDD的应用前景进行了初步分析。1、引言        随着移动通信技术的蓬勃

    2022年5月29日
    46
  • Ubuntu安装与卸载tensorflow

    Ubuntu安装与卸载tensorflow安装sudopipinstalltensorflow-gpu==1.2卸载sudopipuninstalltensorflow-gputensorflow1.2.0配cuda8.0、cudnn5.1

    2022年6月22日
    80
  • initramfs学习「建议收藏」

    initramfs学习「建议收藏」(一)helloworld一、initramfs是什么在2.6版本的linux内核中,都包含一个压缩过的cpio格式的打包文件。当内核启动时,会从这个打包文件中导出文件到内核的rootfs文件系统,然后内核检查rootfs中是否包含有init文件,如果有则执行它,作为PID为1的第一个进程。这个init进程负责启动系统后续的工作,包括定位、挂载“真正的”根文件系统设备(如果有的话)。

    2022年8月11日
    13
  • phpstorm 2021激活码_在线激活

    (phpstorm 2021激活码)最近有小伙伴私信我,问我这边有没有免费的intellijIdea的激活码,然后我将全栈君台教程分享给他了。激活成功之后他一直表示感谢,哈哈~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年3月26日
    60
  • mysql实现主从复制的日志是哪种_Redis主从复制

    mysql实现主从复制的日志是哪种_Redis主从复制Mysql实现主从复制

    2022年8月13日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号