`

JAVA XML解析技术

    博客分类:
  • XML
 
阅读更多

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 xml解析工具类java xml解析...

    java在线解析xmljava在线解析xmljava在线解析xmljava在线解析xml

    java在线解析xmljava在线解析xmljava在线解析xmljava在线解析xmljava在线解析xmljava在线解析xmljava在线解析xmljava在线解析xmljava在线解析xmljava在线解析xmljava在线解析xmljava在线解析xmljava在线解析xmljava...

    java XML解析方式实现自动生成word文档

    本篇文章将详细探讨如何利用Java和XML解析来自动化创建Word文档。 首先,我们需要了解XML的结构。XML(Extensible Markup Language)是一种标记语言,它允许我们以结构化的方式存储数据。在生成Word文档时,我们...

    java xml 解析包

    Java XML解析包主要指的是用于处理XML(eXtensible Markup Language)文档的库,它使得在Java程序中读取、写入、修改和操作XML变得简单。本篇将详细介绍使用Java进行XML解析的关键知识点,以dom4j-1.6.1为例。 1. *...

    Java中四种XML解析技术

    Java中的XML解析技术是开发过程中不可或缺的一部分,尤其是在处理结构化数据时。XML(eXtensible Markup Language)因其可扩展性和灵活性,常被用于存储和交换数据。在Java中,有四种主要的XML解析技术,它们分别是...

    java 解析XML性能对比分析Demo

    本文将深入探讨几种不同的XML解析方法,并通过实际的“Java解析XML性能对比分析Demo”来展示它们的性能差异。我们将讨论DOM、SAX、JDOM、DOM4J和JAXB这五种解析器,以及它们各自的特点和适用场景。 1. DOM(文档...

    java心电图xml解析.zip

    通过研究这个“java心电图xml解析.zip”中的源码,可以深入理解如何在实际项目中应用XML解析技术,以及如何处理特定领域(如医疗)的数据。同时,这也提供了一个学习和实践Java XML解析能力的好机会。

    java实现xml解析word文档代码实现

    Java 实现 XML 解析 Word 文档代码实现 基于给定的文件信息,我们可以总结出以下知识点: 1. Java 实现 XML 解析 Word 文档 Java 可以使用多种方式来解析 Word 文档,包括使用 Apache POI 库、Java2Word 库等。...

    java 解析xml 多级

    Java作为一种广泛使用的后端编程语言,提供了多种方式来解析XML文档,使得处理多级嵌套的数据变得可能。本文将详细讲解如何在Java中解析XML,特别是针对多级结构的情况。 首先,Java提供了两种主要的API来处理XML:...

    java 解析xml并打印输出

    Java XML解析技术是Java开发中常见的一项任务,用于处理XML数据。XML(eXtensible Markup Language)是一种标记语言,广泛用于数据交换、配置存储和文档结构化。本示例着重于如何在Java环境中解析XML文件,并将其...

    XmlUtils.java xml解析工具包

    XML交互时方便进行XML格式转换,包含XML格式数据转换成list对象方法,参数拼接成XML方法

    java-xml解析2

    本文将围绕给定的“java-xml解析”这一主题进行深入探讨。 #### 二、JDBC 与 XML 的关系 尽管提供的部分内容主要介绍了 JDBC(Java Database Connectivity)的相关概念,但这里我们关注的是如何利用 Java 对 XML ...

    Java中四种XML解析技术分析对比

    本篇文章将深入探讨四种主要的XML解析技术——DOM、SAX、StAX以及JAXB,并进行详细的分析与对比。 1. DOM(Document Object Model) DOM解析器将整个XML文档加载到内存中,形成一个树形结构,即DOM树。这种解析方式...

    Java解析XML的jar包+四种解析方法

    java解析xml的四种方法的比较,还有四种方法所用到的jar包 附带程序例子 1.DOM生成和解析XML文档 2.SAX生成和解析XML文档 3.DOM4J生成和解析XML文档 4.JDOM生成和解析XML

    JAVA 解析XML生成XML文档实例

    JAVA 解析XML和生成XML文档源码。比较全 1.DOM生成和解析XML文档 2.SAX生成和解析XML文档 3.DOM4J生成和解析XML文档 4.JDOM生成和解析XML

    XML解析技术研究XML解析技术研究

    XML解析技术是XML应用的核心,它涉及将XML文档转换为可处理的结构化数据。XML,全称为eXtensible Markup Language,是一种元语言,用于描述结构化数据,独立于编程语言、操作系统和传输协议。W3C联盟自1996年开始...

    JAVA XML解析demo可直接使用

    Java XML解析是编程中常见的一项任务,特别是在处理配置文件、数据交换或集成不同系统时。本教程将聚焦于使用DOM4J库进行XML解析的详细步骤。DOM4J是一个非常灵活且功能强大的Java库,它提供了对XML文档的全面处理,...

Global site tag (gtag.js) - Google Analytics