十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
本篇文章为大家展示了利用Java 如何实现解析XML数据,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
创新互联公司主营东乡网站建设的网络公司,主营网站建设方案,重庆App定制开发,东乡h5微信小程序开发搭建,东乡网站营销推广欢迎东乡等地区企业咨询DOM 解析
DOM(Document Object Model, 文档对象模型),在应用程序中,基于 DOM 的 XML 分析器将一个 XML 文档转换成一个对象模型的集合(通常称为 DOM 树 ),应用程序正是通过对这个对象模型的操作,来实现对 XML 文档数据的操作。XML 本身是以树状的形式出现的,所以 DOM 操作的时候,也将按章树的形式进行转换。在整个 DOM 树中,大的地方指的是 Document,表示一个文档,在这个文档中只存在一个根节点。
注意:在使用 DOM 操作的时候,每一个文字的区域也是一个节点,称为文本节点。
核心操作接口
在 DOM 解析中有以下四个核心的操作接口:
Document:此接口代表了整个 XML 文档,表示的是整棵 DOM 树的根,提供了对文档中的数据进行访问和操作的入口,通过 Document 节点可以访问 XML 文件中所有的元素内容。
Node:此接口在整个 DOM 树中具有举足轻重的地位,DOM 操作的核心接口中有很大一部分接口是从 Node 接口继承过来的。例如:Document、Element 等接口,在 DOM 树中,每一个 Node 接口代表了 DOM 树中的一个节点。
NodeList:此接口表示的是一个节点的集合,一般用于表示有顺序关系的一组节点,例如: 一个节点的子节点,当文档改变的时候会直接影响到 NodeList 集合。
NamedNodeMap:此接口表示的是一组节点和其唯一名字对应的一一对应关系,本接口主要用于属性节点的表示上。
DOM 解析过程
如果一个程序需要进行 DOM 解析读取操作的话,也需要按照如下的步骤进行:
建立 DocumentBuilderFactory : DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
建立 DocumentBuilder: DocumentBuilder builder = factory.newDocumentBuilder();
建立 Document : Document doc = builder.parse(“要解析的文件路径”);
建立 NodeList : NodeList nl = doc.getElementsByTagName(“读取节点”);
进行 XML 信息读取
SAX 解析
SAX(Simple API for XML)解析是按照 xml 文件的顺序一步一步的来解析。SAX 没有官方的标准机构,它不属于任何标准组织或团体,也不属于任何公司或个人,而是提供任何人使用的一种计算机技术。
SAX(Simple API for XML,操作 XML 的简单接口),与 DOM 操作不同的是,SAX 采用的是一种顺序的模式进行访问,是一种快速读取 XML 数据的方式。当使用 SAX 解析器进行操作的时候会触发一系列的事情,当扫描到文档(document)开始与结束、元素(element)开始与结束时都会调用相关的处理方法,并由这些操作方法作出相应的操作,直至整个文档扫描结束。
如果要想实现这种 SAX 解析,则肯定首先建立一个 SAX 的解析器。
// 1、创建解析器工厂 SAXParserFactory factory = SAXParserFactory.newInstance(); // 2、获得解析器 SAXParser parser = factory.newSAXParser(); // SAX 解析器 ,继承 DefaultHandler String path = new File("resource/demo01.xml").getAbsolutePath(); // 解析 parser.parse(path, new MySaxHandler());