XML学习总结(三)——SAXReader解析xml文件数据

第一种方式:

1. 加入jar包

注意

    1.1 xml文件解析时编码要一致(默认UTF-8),出现报错可以在记事本中另存为来更改编码格式。

     2.2 jar包两个都需要。


2.gao.xml数据如下:

<?xml version="1.0" encoding="UTF-8"?>
<emps>
	<emp>
		<id>1</id>
		<name>张三</name>
		<age>26</age>
		<gender>男</gender>
		<salary>3000</salary>
	</emp>
	<emp>
		<id>2</id>
		<name>李四</name>
		<age>21</age>
		<gender>女</gender>
		<salary>2000</salary>
	</emp>
	<emp>
		<id>3</id>
		<name>王五</name>
		<age>28</age>
		<gender>女</gender>
		<salary>6500</salary>
	</emp>
	<emp>
		<id>4</id>
		<name>赵六</name>
		<age>28</age>
		<gender>男</gender>
		<salary>5500</salary>
	</emp>
	<emp>
		<id>5</id>
		<name>钱七</name>
		<age>53</age>
		<gender>男</gender>
		<salary>12000</salary>
	</emp>
	<cmp department="总经办">
		<id>007</id>
		<name>董事长</name>
		<age>52</age>
		<gender>男</gender>
		<salary>100000</salary>
	</cmp>
</emps>

3.XmlDemo.java代码

package me.gorden.xml;

import java.io.File;
import java.util.List;

import org.dom4j.Document;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;

public class XmlDemo {
	public static void main(String[] args) {
		try {
			// 创建SAXReader
			SAXReader reader = new SAXReader();
			//从xml文件获取数据  
			Document document = reader.read(new File("E:\\00_MeWockSpace\\MyEclipse 12\\xmlDemo\\src\\gao.xml"));
			// 获取根节点 emps
			Element root = document.getRootElement();
			// 查找指定节点名称QName的所有子节点elements
			List<Element> list = root.elements("emp");  //得到所有emp元素
			System.out.println("list==>"+list);
			
			for (Element element : list) { //循环输出全部emp的相关信息  
				System.out.println("element.getName()==>"+element.getName());
				
				List<Element> list2 = element.elements(); //得到emp元素下的子元素
				
				for (Element e : list2) {  //遍历emp元素下的子元素
					System.out.print(e.getName()+":");  //获取子元素名称
					System.out.print(e.getText()+" ");  //获取子元素的文本值
				}
				 System.out.println();
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
}

4.结果

list==>[org.dom4j.tree.DefaultElement@168afdd [Element: <emp attributes: []/>], org.dom4j.tree.DefaultElement@1f21056 [Element: <emp attributes: []/>], org.dom4j.tree.DefaultElement@10e8647 [Element: <emp attributes: []/>], org.dom4j.tree.DefaultElement@91cf0b [Element: <emp attributes: []/>], org.dom4j.tree.DefaultElement@b00ec2 [Element: <emp attributes: []/>]]
element.getName()==>emp
id:1 name:张三 age:26 gender:男 salary:3000 
element.getName()==>emp
id:2 name:李四 age:21 gender:女 salary:2000 
element.getName()==>emp
id:3 name:王五 age:28 gender:女 salary:6500 
element.getName()==>emp
id:4 name:赵六 age:28 gender:男 salary:5500 
element.getName()==>emp
id:5 name:钱七 age:53 gender:男 salary:12000 

代码解析:
1、读取xml数据
SAXReader可以通过多种方式读取xml数据,并返回Document格式的对象。通过查看源码,可以看出read()方法接收File,InputStream和URL等格式的参数来读取相应的xml数据。在代码里我演示了读取xml文档和xml格式的字符串两种方式。当然,字符串要根据相应的编码转成输入流才能被SAXReader读取。
2、解析xml数据
读取到Document对象后,我们使用getRootElement()方法获取根元素,返回的是一个Element对象。在本例中,该元素的name即为emps。
3、获取子元素数据
获取根元素后,便可以一层一层的去获取他的子元素信息。如果知道子元素的标签名称,便可以直接调用element("name")方法获取该子元素。如果不知道子元素的名称,或者想直接获取该元素下的全部子元素,可以调用elements()方法获取一个包括全部元素的list,然后进行下一步的处理。
4、输出元素信息
调用getName()方法获取当前元素的元素名,attributeValue()获取属性名。如果当前元素没有子元素,则调用getText()方法获取元素值。

第二种方式:

1.ReadXml.java文件和上面的不一样,其余的都是一样的

package me.gorden.xml;

import java.io.File;
import java.util.List;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;

public class ReadXml {
	public static void main(String[] args) throws DocumentException {
		File file = new File("E:\\00_MeWockSpace\\MyEclipse 12\\xmlDemo\\src\\gao.xml");
		
		System.out.println("file===>"+file);
		// 创建SAXReader
		SAXReader reader = new SAXReader();
		// 用SAXReader来读取文件,并转换成Document
		Document document = reader.read(file);
		//用Document的selectNodes来读取节点,返回list
		List<Object> list = document.selectNodes("/emps/emp/name");
		Element e = null;
		if(list.size()>0){
			e = (Element) list.get(0);
		}
		
		System.out.println("list.size()==>"+list.size());
		
		if(null != e){
			Object obj = e.getData();
			System.out.println("Element内容为:  "+obj);
		}else{
			System.out.println("Element内容为空");
		}
		
	}
}

2.结果

file===>E:\00_MeWockSpace\MyEclipse 12\xmlDemo\src\gao.xml
list.size()==>5
Element内容为:  张三

参考文档:https://blog.csdn.net/u011291072/article/details/53492461

  • 10
    点赞
  • 78
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
SAX(Simple API for XML解析器是一种基于事件驱动的解析器,它逐行扫描XML文档并触发事件,当解析器发现XML元素、属性或字符数据时,会触发相应的事件,应用程序可以在事件发生时采取相应的行动。 在Java中,可以使用SAX解析解析XML文档。其中,SAX解析器的核心类是DefaultHandler,开发人员可以继承该类并实现其中的方法以处理XML文档中的事件。 下面是一个使用SAX解析解析XML文档的示例代码: ```java 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 MySAXParser extends DefaultHandler { public static void main(String[] args) { try { SAXParserFactory factory = SAXParserFactory.newInstance(); SAXParser parser = factory.newSAXParser(); MySAXParser handler = new MySAXParser(); parser.parse("file.xml", handler); } catch (Exception e) { e.printStackTrace(); } } public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException { // 处理XML元素开始事件 } public void endElement(String uri, String localName, String qName) throws SAXException { // 处理XML元素结束事件 } public void characters(char[] ch, int start, int length) throws SAXException { // 处理XML字符数据事件 } } ``` 在上述代码中,我们首先创建了一个SAXParserFactory实例,然后使用该实例创建一个SAXParser实例。接着,我们创建了一个自定义的MySAXParser类,它继承自DefaultHandler,并实现了其中的startElement、endElement和characters方法以处理XML文档中的事件。最后,我们调用SAXParser的parse方法,并将MySAXParser实例作为参数传递给它,以便在解析XML文档时处理事件。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xinlianluohan

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值