SAX解析XML并把节点值保存到相应的对象中

一、book.xml:

<?xml version="1.0" encoding="UTF-8"?>
<bookstore>
	<book id="1">
		<name>冰与火之歌</name>
		<author>乔治马丁</author>
		<year>2014</year>
		<price>89</price>
	</book>
	<book id="2">
		<name>安徒生童话</name>
		<year>2004</year>
		<price>77</price>
		<language>English</language>
	</book>
</bookstore>



二、hnadler类:

import java.util.ArrayList;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
import com.imooc.entity.Book;

public class SAXParserHandler extends DefaultHandler {
	String value = null;
	Book book = null;
	private ArrayList<Book> bookList = new ArrayList<Book>();
	public ArrayList<Book> getBookList() {
		return bookList;
	}

	int bookIndex = 0;
	/**
	 * 用来标识解析开始
	 */
	@Override
	public void startDocument() throws SAXException {
		// TODO Auto-generated method stub
		super.startDocument();
		System.out.println("SAX解析开始");
	}
	
	/**
	 * 用来标识解析结束
	 */
	@Override
	public void endDocument() throws SAXException {
		// TODO Auto-generated method stub
		super.endDocument();
		System.out.println("SAX解析结束");
	}
	
	/**
	 * 解析xml元素
	 */
	@Override
	public void startElement(String uri, String localName, String qName,
			Attributes attributes) throws SAXException {
		//调用DefaultHandler类的startElement方法
		super.startElement(uri, localName, qName, attributes);
		if (qName.equals("book")) {
			bookIndex++;
			//创建一个book对象
			book = new Book();
			//开始解析book元素的属性
			System.out.println("======================开始遍历某一本书的内容=================");
//			//已知book元素下属性的名称,根据属性名称获取属性值
//			String value = attributes.getValue("id");
//			System.out.println("book的属性值是:" + value);
			//不知道book元素下属性的名称以及个数,如何获取属性名以及属性值
			int num = attributes.getLength();
			for(int i = 0; i < num; i++){
				System.out.print("book元素的第" + (i + 1) +  "个属性名是:"
						+ attributes.getQName(i));
				System.out.println("---属性值是:" + attributes.getValue(i));
				if (attributes.getQName(i).equals("id")) {
					book.setId(attributes.getValue(i));
				}
			}
		}
		else if (!qName.equals("name") && !qName.equals("bookstore")) {
			System.out.print("节点名是:" + qName + "---");
		}
	}
	
	@Override
	public void endElement(String uri, String localName, String qName)
			throws SAXException {
		//调用DefaultHandler类的endElement方法
		super.endElement(uri, localName, qName);
		//判断是否针对一本书已经遍历结束
		if (qName.equals("book")) {
			bookList.add(book);
			book = null;
			System.out.println("======================结束遍历某一本书的内容=================");
		}
		else if (qName.equals("name")) {
			book.setName(value);
		}
		else if (qName.equals("author")) {
			book.setAuthor(value);
		}
		else if (qName.equals("year")) {
			book.setYear(value);
		}
		else if (qName.equals("price")) {
			book.setPrice(value);
		}
		else if (qName.equals("language")) {
			book.setLanguage(value);
		}
	}	
	
	@Override
	public void characters(char[] ch, int start, int length)
			throws SAXException {
		// TODO Auto-generated method stub
		super.characters(ch, start, length);
		value = new String(ch, start, length);
		if (!value.trim().equals("")) {
			System.out.println("节点值是:" + value);
		}
	}
}


三、测试类:

import java.io.IOException;
import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;
import org.xml.sax.SAXException;
import org.xml.sax.SAXParseException;
import com.imooc.entity.Book;
import com.imooc.handler.SAXParserHandler;

public class SAXTest {
	public static void main(String[] args) {
		//获取一个SAXParserFactory的实例
<span style="white-space:pre">		</span>SAXParserFactory factory = SAXParserFactory.newInstance();
<span style="white-space:pre">		</span>//通过factory获取SAXParser实例
<span style="white-space:pre">		</span>try {
<span style="white-space:pre">			</span>SAXParser parser = factory.newSAXParser();
<span style="white-space:pre">			</span>//创建SAXParserHandler对象
			SAXParserHandler handler = new SAXParserHandler();
			parser.parse("books.xml", handler);
			System.out.println("~!~!~!共有" + handler.getBookList().size()
					+ "本书");
			for (Book book : handler.getBookList()) {
				System.out.println(book.getId());
				System.out.println(book.getName());
				System.out.println(book.getAuthor());
				System.out.println(book.getYear());
				System.out.println(book.getPrice());
				System.out.println(book.getLanguage());
				System.out.println("----finish----");
			}
		} catch (ParserConfigurationException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (SAXException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}

}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用 SAX 解析器获取 XML 节点的子节点,可以在 DefaultHandler 类的子类重写 startElement() 方法,处理 XML 文件的开始标签,并在其获取子节点。在 startElement() 方法,可以使用 Attributes 对象获取当前开始标签的属性,并使用 XMLReader 对象获取当前节点的子节点。下面是一个示例代码,演示如何使用 SAX 解析器获取 XML 节点的子节点: ```java import javax.xml.parsers.*; import org.xml.sax.*; import org.xml.sax.helpers.*; public class SAXParserExample extends DefaultHandler { private String currentNode; public static void main(String[] args) throws Exception { SAXParserFactory factory = SAXParserFactory.newInstance(); SAXParser parser = factory.newSAXParser(); SAXParserExample handler = new SAXParserExample(); parser.parse("example.xml", handler); } public void startElement(String uri, String localName, String qName, Attributes attributes) { currentNode = qName; if (qName.equals("book")) { String id = attributes.getValue("id"); System.out.println("Book ID: " + id); } } public void characters(char[] ch, int start, int length) { String text = new String(ch, start, length); if (currentNode.equals("title")) { System.out.println("Book Title: " + text); } if (currentNode.equals("author")) { System.out.println("Book Author: " + text); } } } ``` 在上面的代码,我们重写了 DefaultHandler 类的 startElement() 方法和 characters() 方法。在 startElement() 方法,我们使用 currentNode 变量记录当前节点的名称,如果当前节点是 book 节点,则使用 Attributes 对象获取 book 节点的 id 属性。在 characters() 方法,我们通过判断 currentNode 变量的,获取 book 节点的 title 和 author 子节点的文本内容。注意,在 startElement() 方法,我们不能直接获取子节点的文本内容,因为子节点的文本内容可能会被分为多个片段,分别在 characters() 方法处理。因此,我们需要使用一个变量来记录当前节点的名称,在 characters() 方法根据节点名称来处理文本内容。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值