XML基本介绍及DOM4J

XML

1.简介

XML(Extensible Markup Language)是一种类似于 HTML,但是没有使用预定义标记的语言。
XML与HTML类似,也是文档树的结构,由唯一的根节点和其他子节点组成

2.解析XML文件方式

XML解析方式有两种:DOM解析及SAX解析,现在常用SAX解析

3.Java中使用 DOM4J 解析XML文件的步骤

DOM4J是第三方的 jar 包,需要导入 jar 包才能使用

  <dependency>
     <groupId>org.dom4j</groupId>
     <artifactId>dom4j</artifactId>
     <version>2.1.3</version>
   </dependency>

以下是读取XML文件的步骤(具体操作由需求决定,这里只是方法的使用演示)

public class XMLDemo {
    // 读取XML文件
    public static void demo(String path) throws Exception {
        File file=new File(path);
        // 创建SAX解析器对象
        SAXReader saxReader=new SAXReader();
        // 读取XML文件获取文档对象
        Document document = saxReader.read(file);
        // 获取文档中的根节点
        Element rootElement = document.getRootElement();
        // 获取节点下的其他节点,返回一个包含该节点下
        // 所有子节点的节点对象的 list 集合
        List<Element> elements = rootElement.elements();
        // 获取节点的属性值 这里获取名为id的属性值
        String id = rootElement.attributeValue("id");
    }
}

创建XML文件也是同理,只是方法不同

public class XMLDemo {
   // 创建XML文件
   public static void demo() throws Exception {
       // 创建文档对象
       Document document= DocumentHelper.createDocument();
       // 向文档对象中添加根节点
       Element students = document.addElement("students");
       // 向根节点中添加节点
       Element student = students.addElement("student");
       // 给节点添加属性
       student.addAttribute("id", "1");
       // 给节点赋值
       student.addText("hello");
       // 设置生成XML文件格式
       OutputFormat of=OutputFormat.createPrettyPrint();
       // 设置编码格式   其实不设置也行,因为默认UTF-8
       of.setEncoding("UTF-8");
       // 获取XML输出流 将文件输出到指定路径
       XMLWriter xml=new XMLWriter(new FileWriter("f://students.xml"));
       // 将创建的文档输出
       xml.write(document);
       // 释放资源
       xml.close();
   }
}
  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
DOM和dom4j都是用于解析XML文档的工具,它们的使用方法略有不同。下面分别介绍DOM和dom4j解析XML的使用方法: 1. 使用DOM解析XML 使用DOM解析XML时,需要按照以下步骤进行: ```java // 1. 创建 DocumentBuilderFactory 对象 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); // 2. 创建 DocumentBuilder 对象 DocumentBuilder builder = factory.newDocumentBuilder(); // 3. 通过 DocumentBuilder 解析 XML 文件,得到 Document 对象 Document document = builder.parse(new File("xml文件路径")); // 4. 获取根节点 Element root = document.getDocumentElement(); // 5. 获取子节点、属性节点等 NodeList nodeList = root.getElementsByTagName("节点名称"); for (int i = 0; i < nodeList.getLength(); i++) { Node node = nodeList.item(i); if (node.getNodeType() == Node.ELEMENT_NODE) { Element element = (Element) node; // 获取子节点等操作 } else if (node.getNodeType() == Node.ATTRIBUTE_NODE) { Attr attribute = (Attr) node; // 获取属性节点等操作 } } ``` 2. 使用dom4j解析XML 使用dom4j解析XML时,需要按照以下步骤进行: ```java // 1. 读取 XML 文件 SAXReader reader = new SAXReader(); Document document = reader.read(new File("xml文件路径")); // 2. 获取根节点 Element root = document.getRootElement(); // 3. 获取子节点、属性节点等 List<Element> nodeList = root.elements("节点名称"); for (Element element : nodeList) { // 获取子节点等操作 List<Attribute> attributeList = element.attributes(); for (Attribute attribute : attributeList) { // 获取属性节点等操作 } } ``` 以上是DOM和dom4j解析XML基本使用方法。需要注意的是,使用DOM解析XML时,由于要将整个XML文档加载到内存中,因此对于大型XML文档,可能会出现内存溢出等问题。而dom4j相对于DOM,提供了更加方便的API和更高效的内存管理方式,因此在解析大型XML文档时,dom4j可能更加适合。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值