首页 > Java > 正文

Java中XML的用法_Java中XML文件的读写

裘德小鎮的故事
发布: 2025-06-29 23:46:01
原创
884人浏览过

java中处理xml的常见方法包括dom、sax和stax。1.dom适合小型文件,将整个文档加载到内存中便于随机访问和修改;2.sax是事件驱动解析器,适用于大文件,逐行读取且内存占用低但编写复杂;3.stax也是事件驱动,比sax更易用,适合写入和读取。选择解析器需根据文件大小和需求:小文件用dom,大文件用sax或stax。创建xml可用dom构建document对象并写入文件,或使用stax的xmlstreamwriter。验证xml可通过schema(xsd)确保结构有效性,java提供相应api支持验证。

Java中XML的用法_Java中XML文件的读写

XML在Java中主要用于数据存储和传输,它提供了一种结构化的方式来组织信息,方便不同系统之间交换数据。读写XML文件是Java开发中的常见任务,涉及解析XML文档并从中提取数据,或者创建新的XML文档并写入数据。

Java中XML的用法_Java中XML文件的读写

解决方案:

Java中XML的用法_Java中XML文件的读写

Java提供了多种解析XML的API,包括DOM、SAX和StAX。DOM将整个XML文档加载到内存中,形成一个树状结构,方便随机访问和修改,但对于大型XML文件可能会消耗大量内存。SAX是一种事件驱动的解析器,逐行读取XML文档,并在遇到开始标签、结束标签等事件时触发相应的回调函数,内存占用较小,但编写起来相对复杂。StAX是另一种事件驱动的API,提供了比SAX更高级的抽象,更容易使用。

立即学习Java免费学习笔记(深入)”;

Java中XML的用法_Java中XML文件的读写

以下是一个使用DOM解析XML文件的示例:

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import java.io.File;

public class DOMExample {

    public static void main(String[] args) {
        try {
            File xmlFile = new File("example.xml");
            DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
            DocumentBuilder dBuilder = dbFactory.newDocumentBuilder();
            Document doc = dBuilder.parse(xmlFile);

            doc.getDocumentElement().normalize();

            System.out.println("Root element :" + doc.getDocumentElement().getNodeName());

            NodeList nList = doc.getElementsByTagName("student");

            for (int temp = 0; temp < nList.getLength(); temp++) {
                Node nNode = nList.item(temp);

                if (nNode.getNodeType() == Node.ELEMENT_NODE) {
                    Element eElement = (Element) nNode;
                    System.out.println("Student id : " + eElement.getAttribute("id"));
                    System.out.println("First Name : " + eElement.getElementsByTagName("firstname").item(0).getTextContent());
                    System.out.println("Last Name : " + eElement.getElementsByTagName("lastname").item(0).getTextContent());
                    System.out.println("Marks : " + eElement.getElementsByTagName("marks").item(0).getTextContent());
                }
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}
登录后复制

这段代码首先创建了一个DocumentBuilderFactory和DocumentBuilder,然后使用parse方法将XML文件解析成一个Document对象。接着,它获取根元素,并遍历所有的student元素,打印出每个学生的id、firstname、lastname和marks。

以下是一个使用SAX解析XML文件的示例:

import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;

import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import java.io.File;

public class SAXExample {

    public static void main(String[] args) {

        try {

            File inputFile = new File("example.xml");
            SAXParserFactory factory = SAXParserFactory.newInstance();
            SAXParser saxParser = factory.newSAXParser();
            UserHandler userhandler = new UserHandler();
            saxParser.parse(inputFile, userhandler);

        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

class UserHandler extends DefaultHandler {

    boolean bfname = false;
    boolean blname = false;
    boolean bmarks = false;

    @Override
    public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {

        if (qName.equalsIgnoreCase("student")) {
            String rollNo = attributes.getValue("id");
            System.out.println("Roll No : " + rollNo);
        } else if (qName.equalsIgnoreCase("firstname")) {
            bfname = true;
        } else if (qName.equalsIgnoreCase("lastname")) {
            blname = true;
        } else if (qName.equalsIgnoreCase("marks")) {
            bmarks = true;
        }
    }

    @Override
    public void endElement(String uri, String localName, String qName) throws SAXException {
        if (qName.equalsIgnoreCase("student")) {
            System.out.println("</student>");
        }
    }

    @Override
    public void characters(char ch[], int start, int length) throws SAXException {

        if (bfname) {
            System.out.println("First Name : " + new String(ch, start, length));
            bfname = false;
        }

        if (blname) {
            System.out.println("Last Name : " + new String(ch, start, length));
            blname = false;
        }

        if (bmarks) {
            System.out.println("Marks : " + new String(ch, start, length));
            bmarks = false;
        }
    }
}
登录后复制

这个例子定义了一个UserHandler类,继承自DefaultHandler,并重写了startElement、endElement和characters方法。当SAX解析器遇到开始标签时,会调用startElement方法;遇到结束标签时,会调用endElement方法;遇到文本内容时,会调用characters方法。通过这些回调函数,我们可以提取XML文档中的数据。

如何选择合适的XML解析器?

选择XML解析器取决于你的具体需求。如果XML文件较小,并且需要随机访问和修改数据,那么DOM是一个不错的选择。如果XML文件很大,并且只需要顺序读取数据,那么SAX或StAX更适合。StAX通常被认为比SAX更易于使用。

如何创建和写入XML文件?

可以使用DOM或StAX来创建和写入XML文件。使用DOM时,首先创建一个Document对象,然后创建元素和属性,并将它们添加到Document对象中。最后,将Document对象写入到文件中。使用StAX时,创建一个XMLStreamWriter对象,然后使用writeStartElement、writeAttribute和writeCharacters等方法来写入XML数据。

XML Schema验证是什么?

XML Schema验证是验证XML文档是否符合特定Schema(XSD)的过程。Schema定义了XML文档的结构、元素和属性的类型以及它们之间的关系。通过Schema验证,可以确保XML文档的格式和内容是有效的,从而提高数据的可靠性和互操作性。Java提供了API来进行XML Schema验证。

以上就是Java中XML的用法_Java中XML文件的读写的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号