dom4j解析无根节点的xml

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了dom4j解析无根节点的xml相关的知识,希望对你有一定的参考价值。

<cdr><ID>10</ID><Name>11</Name><Age>12</Age><Sex>13</Sex></cdr><cdr><ID>1</ID><Name>2</Name><Age>3</Age><Sex>4</Sex></cdr>本人是菜鸟,求高手写全代码,谢谢!这个xml文件时由多个cdr组成没有主根节点。

参考技术A public static void main(String[] args)
SAXReader saxReader = new SAXReader();
Document document;
try
document = saxReader.read(new File(Dom4jParse.class.getClass()
.getResource("/").getFile().toString()
+ "test.xml"));
Element root = document.getRootElement();
List list = new ArrayList();
//List里存放的是BEAN对象的值
new Dom4jParse().parse(root , list);
for (Iterator iterator = list.iterator(); iterator.hasNext();)
Bean bean = (Bean) iterator.next();
System.out.println("ID:" + bean.getId() + "\nAge:" + bean.getAge() + "\nName:" + bean.getName());

catch (Exception e)
// TODO Auto-generated catch block
e.printStackTrace();



/*
* 获得X属性结果是X值的整个标签
*/
public void parse(Element node ,List list)
Iterator iters = node.elementIterator("cdr");
while(iters.hasNext())
Element itemEle = (Element) iters.next();
Bean bean = new Bean();
bean.setId(itemEle.elementText("ID") != null ? itemEle.elementText("ID") : "");
bean.setAge(itemEle.elementText("Name") != null ?itemEle.elementText("Name") : "");
bean.setName(itemEle.elementText("Age") != null ?itemEle.elementText("Age") : "");
list.add(bean);


简单了点,自己去加强追问

Dom4jParse 这个是什么?为什么我复制你的报错呢,包我已经导入了dom4j的包。你导入的是哪个?

追答

当前类名

追问

那解析bean的时候要把这个bean类所有的属性都需要循环出来吗?

追答

这个肯定是看需求。不过你XML最好是每个节点对应一个BEAN属性。不管用于不用你至少要存起来

追问

你写的还是不能解析出来,报异常。

追答

什么异常,你贴出来?

本回答被提问者采纳

XML引入,DOM 方式解析XML 原理,SAX 方式解析XML

XML 简介

Xml(eXtensible Markup Language) 即可扩展标记语言。
提供了一套跨平台、跨网络、跨程序的语言的数据描述方式,使用XML 可以方便地实现数据交换、系统配置、
内容管理等常见功能。

元素VS 节点

节点包括元素节点、属性节点、文本节点;
元素一定是节点,但是节点不一定是元素;

<?xml version="1.0" encoding="UTF-8"?>
<emp>
	<empName empNo="10050">Allen</empName>
	<job>办事员</job>
	<addr>波士顿</addr>
</emp>

  DOM 方式解析XML 原理

基于DOM(Document Object Model,文档对象模型)解析方式,是把整个XML 文档加载到内存,转化成
DOM 树,因此应用程序可以随机的访问DOM 树的任何数据;
优点:灵活性强,速度快;
缺点:消耗资源比较多;

  DOM 方式解析XML 示例

<?xml version="1.0" encoding="UTF-8"?>
<emps>
<emp>
	<empName empNo="10050">Allen</empName>
	<job>办事员</job>
	<addr>波士顿</addr>
</emp>
<emp>
	<empName empNo="10060">Smith</empName>
	<job>销售员</job>
	<addr>纽约</addr>
</emp>
<emp>
	<empName empNo="10070">James</empName>
	<job>技术员</job>
	<addr>北京</addr>
</emp>
</emps>

  

package com.zhiqi.test;

import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;

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

public class DOM {

	public static void printNodeAttr(Node node){
		NamedNodeMap namedNodeMap=node.getAttributes();
		for(int i=0;i<namedNodeMap.getLength();i++){
			Node attrNode=namedNodeMap.item(i);
			System.out.println(attrNode.getNodeName()+":"+attrNode.getFirstChild().getNodeValue());
		}
	}
	
	public static void main(String[] args) {
		DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();
		try {
			DocumentBuilder builder=factory.newDocumentBuilder();
			Document doc=builder.parse("src/emp.xml");
			NodeList nodeList=doc.getElementsByTagName("emps");
			Element element=(Element)nodeList.item(0);
			NodeList studentsNodeList=element.getElementsByTagName("emp");
			for(int i=0;i<studentsNodeList.getLength();i++){
				Element e=(Element)studentsNodeList.item(i);
				System.out.println("姓名:"+e.getElementsByTagName("empName").item(0).getFirstChild().getNodeValue());
				printNodeAttr(e.getElementsByTagName("empName").item(0));
				System.out.println("职位:"+e.getElementsByTagName("job").item(0).getFirstChild().getNodeValue());
				System.out.println("地址:"+e.getElementsByTagName("addr").item(0).getFirstChild().getNodeValue());
				System.out.println("================");
			}
		} catch (Exception e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
}

 

 

 

  SAX 方式解析XML

<?xml version="1.0" encoding="UTF-8"?>
<emp>
	<empName empNo="10050">Allen</empName>
	<job>办事员</job>
	<addr>波士顿</addr>
</emp>

  

package com.zhiqi.test;

import java.io.IOException;

import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;

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

public class SAX extends DefaultHandler{

@Override
	public void startDocument() throws SAXException {
		System.out.println("扫描开始");
	}

	@Override
	public void endDocument() throws SAXException {
		System.out.println("扫描结束");
	}

	@Override
	public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {
		System.out.println("开始扫描元素"+qName);
	}

	@Override
	public void endElement(String uri, String localName, String qName) throws SAXException {
		System.out.println("结束扫描元素"+qName);
	}

	@Override
	public void characters(char[] ch, int start, int length) throws SAXException {
		System.out.println("扫描文本节点"+new String(ch,start,length));
	}
	
	public static void main(String[] args) throws ParserConfigurationException, SAXException, IOException {
		SAXParserFactory factory=SAXParserFactory.newInstance();
		SAXParser parser=factory.newSAXParser();
		parser.parse("src/emp2.xml", new SAX());
	}
}

  

aaa

以上是关于dom4j解析无根节点的xml的主要内容,如果未能解决你的问题,请参考以下文章

JavaEE XML DOM4J解析

【求助】Dom4j 生成xml,节点增加属性时,属性值中有特殊字符,如何做到不转义

使用Dom4j对XML文档创建与解析

dom4j 解析生成xml 案例

dom4j解析xml重复节点

解析和操作XML文件