DOM解析方式:
@Test public void DOMTest() { try { DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = factory.newDocumentBuilder(); Document document = builder.parse(XML4JAVA.class.getClassLoader().getResourceAsStream( "context.xml")); NodeList list = document.getElementsByTagName("bean"); for (int i = 0; i < list.getLength(); i++) { Element element = (Element) list.item(i); System.out.print(element.getAttribute("id") + "="); System.out.println(element.getAttribute("class")); } } catch (ParserConfigurationException e) { e.printStackTrace(); } catch (SAXException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } @Test public void DomTest02() { try { DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = factory.newDocumentBuilder(); Document document = builder.parse(XML4JAVA.class.getClassLoader().getResourceAsStream( "context.xml")); Element root = document.getDocumentElement(); parseElement(root); } catch (ParserConfigurationException e) { e.printStackTrace(); } catch (SAXException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } private void parseElement(Element element) { String tagName = element.getNodeName(); NodeList children = element.getChildNodes(); NamedNodeMap map = element.getAttributes(); System.out.print("<" + tagName); if (null != map) { for (int i = 0; i < map.getLength(); i++) { Attr attr = (Attr) map.item(i); System.out.print(" " + attr.getName() + "=\"" + attr.getValue() + "\""); } } System.out.print(">"); for (int i = 0; i < children.getLength(); i++) { Node node = children.item(i); short nodeType = node.getNodeType(); if (nodeType == Node.ELEMENT_NODE) { parseElement((Element) node); } else if (nodeType == Node.TEXT_NODE) { System.out.print(node.getNodeValue()); } else if (nodeType == Node.COMMENT_NODE) { System.out.print("<!--"); Comment comment = (Comment) node; System.out.print(comment.getData()); System.out.print("-->"); } } System.out.print("</" + tagName + ">"); }
SAX解析方式:
@Test public void testSax() { try { SAXParserFactory factory = SAXParserFactory.newInstance(); SAXParser parser = factory.newSAXParser(); InputStream is = XML4JAVA.class.getClassLoader().getResourceAsStream("context.xml"); DefaultHandler dh = new BeanHandler(); parser.parse(is, dh); if (dh instanceof BeanHandler) { Map<String, String> map = ((BeanHandler) dh).getMap(); for (String key : map.keySet()) { System.out.println(key + ":" + map.get(key)); } } } catch (ParserConfigurationException e) { e.printStackTrace(); } catch (SAXException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } class BeanHandler extends DefaultHandler { private String key; private String value; private Map<String, String> map = new HashMap<String, String>(); public Map<String, String> getMap() { return map; } @Override public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException { if ("bean".equals(qName)) { for (int i = 0; i < attributes.getLength(); i++) { String k = attributes.getQName(i); String v = attributes.getValue(i); if (k.equals("id")) { key = v; } else if (k.equals("class")) { value = v; } } map.put(key, value); } } }
DOM4J解析方式:
package org.yzr.utils; import java.io.File; import java.io.FileWriter; import java.io.IOException; import java.io.UnsupportedEncodingException; import java.util.List; import org.dom4j.Attribute; import org.dom4j.Document; import org.dom4j.DocumentHelper; import org.dom4j.Element; import org.dom4j.io.OutputFormat; import org.dom4j.io.SAXReader; import org.dom4j.io.XMLWriter; import org.junit.Test; public class DOM4J { @Test public void testCreate() { try { Document document = DocumentHelper.createDocument(); Element root = DocumentHelper.createElement("root"); document.setRootElement(root); root.addAttribute("id", "1"); Element first = root.addElement("first"); first.addAttribute("id", "2"); first.setText("第一个"); Element second = root.addElement("second"); second.addAttribute("id", "3"); second.setText("第二个"); OutputFormat format = new OutputFormat("\t", true, "UTF-8"); XMLWriter writer = new XMLWriter(new FileWriter("dom4j.xml"), format); writer.write(document); writer.close(); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } @Test public void testRead() { SAXReader reader; try { reader = new SAXReader(); Document document = reader.read(new File("dom4j.xml")); Element root = document.getRootElement(); System.out.println(root.getName()); List<Element> eles = root.elements(); for (int i = 0; i < eles.size(); i++) { Element e = eles.get(i); System.out.println(e.getName()); List<Attribute> attrs = e.attributes(); for (int j = 0; j < attrs.size(); j++) { if (attrs.get(j).getName().equals("id")) { System.out.println("id=" + attrs.get(j).getValue()); } } System.out.println(e.getText()); } } catch (Exception e) { e.printStackTrace(); } } }
JDOM解析方式:
package org.yzr.utils; import java.io.File; import java.io.FileWriter; import java.io.IOException; import java.util.List; import org.jdom2.Attribute; import org.jdom2.Comment; import org.jdom2.Document; import org.jdom2.Element; import org.jdom2.JDOMException; import org.jdom2.input.SAXBuilder; import org.jdom2.output.Format; import org.jdom2.output.XMLOutputter; import org.junit.Test; public class JDOM { @Test public void testCreate() { try { Document document = new Document(); Comment comment = new Comment("创建XML"); document.addContent(comment); Element root = new Element("root"); root.setAttribute(new Attribute("id", "root")); Element first = new Element("first"); first.setAttribute(new Attribute("id", "first")); first.addContent("first"); Element second = new Element("second"); second.setAttribute(new Attribute("id", "second")); second.addContent("second"); root.addContent(first); root.addContent(second); document.addContent(root); Format format = Format.getPrettyFormat(); format.setIndent("\t"); XMLOutputter out = new XMLOutputter(format); out.output(document, new FileWriter("jdom.xml")); } catch (IOException e) { e.printStackTrace(); } } @Test public void testRead() { try { SAXBuilder builder = new SAXBuilder(); Document document = builder.build(new File("jdom.xml")); Element root = document.getRootElement(); System.out.print(root.getName()); Element second = root.getChild("second"); List<Attribute> list = second.getAttributes(); for (int i = 0; i < list.size(); i++) { Attribute attribute = list.get(i); System.out.print(attribute.getName() + "=\""); System.out.print(attribute.getValue() + "\""); } second.setText("2"); XMLOutputter outputter = new XMLOutputter(Format.getPrettyFormat().setIndent("\t")); outputter.output(document, new FileWriter("jdom.xml")); } catch (JDOMException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } }
相关推荐
java xml解析工具类 java xml解析工具类java xml解析工具类 java xml解析工具类java xml解析工具类 java xml解析工具类java xml解析工具类 java xml解析工具类java xml解析工具类 java xml解析工具类java xml解析...
java在线解析xmljava在线解析xmljava在线解析xmljava在线解析xmljava在线解析xmljava在线解析xmljava在线解析xmljava在线解析xmljava在线解析xmljava在线解析xmljava在线解析xmljava在线解析xmljava在线解析xmljava...
本篇文章将详细探讨如何利用Java和XML解析来自动化创建Word文档。 首先,我们需要了解XML的结构。XML(Extensible Markup Language)是一种标记语言,它允许我们以结构化的方式存储数据。在生成Word文档时,我们...
Java XML解析包主要指的是用于处理XML(eXtensible Markup Language)文档的库,它使得在Java程序中读取、写入、修改和操作XML变得简单。本篇将详细介绍使用Java进行XML解析的关键知识点,以dom4j-1.6.1为例。 1. *...
Java中的XML解析技术是开发过程中不可或缺的一部分,尤其是在处理结构化数据时。XML(eXtensible Markup Language)因其可扩展性和灵活性,常被用于存储和交换数据。在Java中,有四种主要的XML解析技术,它们分别是...
本文将深入探讨几种不同的XML解析方法,并通过实际的“Java解析XML性能对比分析Demo”来展示它们的性能差异。我们将讨论DOM、SAX、JDOM、DOM4J和JAXB这五种解析器,以及它们各自的特点和适用场景。 1. DOM(文档...
通过研究这个“java心电图xml解析.zip”中的源码,可以深入理解如何在实际项目中应用XML解析技术,以及如何处理特定领域(如医疗)的数据。同时,这也提供了一个学习和实践Java XML解析能力的好机会。
Java 实现 XML 解析 Word 文档代码实现 基于给定的文件信息,我们可以总结出以下知识点: 1. Java 实现 XML 解析 Word 文档 Java 可以使用多种方式来解析 Word 文档,包括使用 Apache POI 库、Java2Word 库等。...
Java作为一种广泛使用的后端编程语言,提供了多种方式来解析XML文档,使得处理多级嵌套的数据变得可能。本文将详细讲解如何在Java中解析XML,特别是针对多级结构的情况。 首先,Java提供了两种主要的API来处理XML:...
Java XML解析技术是Java开发中常见的一项任务,用于处理XML数据。XML(eXtensible Markup Language)是一种标记语言,广泛用于数据交换、配置存储和文档结构化。本示例着重于如何在Java环境中解析XML文件,并将其...
XML交互时方便进行XML格式转换,包含XML格式数据转换成list对象方法,参数拼接成XML方法
本文将围绕给定的“java-xml解析”这一主题进行深入探讨。 #### 二、JDBC 与 XML 的关系 尽管提供的部分内容主要介绍了 JDBC(Java Database Connectivity)的相关概念,但这里我们关注的是如何利用 Java 对 XML ...
本篇文章将深入探讨四种主要的XML解析技术——DOM、SAX、StAX以及JAXB,并进行详细的分析与对比。 1. DOM(Document Object Model) DOM解析器将整个XML文档加载到内存中,形成一个树形结构,即DOM树。这种解析方式...
java解析xml的四种方法的比较,还有四种方法所用到的jar包 附带程序例子 1.DOM生成和解析XML文档 2.SAX生成和解析XML文档 3.DOM4J生成和解析XML文档 4.JDOM生成和解析XML
JAVA 解析XML和生成XML文档源码。比较全 1.DOM生成和解析XML文档 2.SAX生成和解析XML文档 3.DOM4J生成和解析XML文档 4.JDOM生成和解析XML
XML解析技术是XML应用的核心,它涉及将XML文档转换为可处理的结构化数据。XML,全称为eXtensible Markup Language,是一种元语言,用于描述结构化数据,独立于编程语言、操作系统和传输协议。W3C联盟自1996年开始...
Java XML解析是编程中常见的一项任务,特别是在处理配置文件、数据交换或集成不同系统时。本教程将聚焦于使用DOM4J库进行XML解析的详细步骤。DOM4J是一个非常灵活且功能强大的Java库,它提供了对XML文档的全面处理,...