Java_SAX解析XML

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


public class RSSHandler extends DefaultHandler {
	static int cur=-1;
	/**
	 * characters回调函数:当解析到一个节点后就会调用这个函数来接收节点后面的数据,例如<name>数据</name>,解析完<name>节点后调用该函数接受节点后面的数据
	 */
	public void characters(char[] ch, int start, int length)
			throws SAXException {
		// TODO 自动生成的方法存根
		super.characters(ch, start, length);
		String str=new String(ch,start,length);
		switch(cur)
		{
		case 2:
			System.out.print(str+"  ");
			break;
		case 3:
			System.out.print(str+"  ");
			break;
		case 4:
			break;
		default:
			break;
		}
	}

	/**
	 * endDocument函数:解析完一个文档后会调用改函数,且只调用一次
	 */
	public void endDocument() throws SAXException {
		// TODO 自动生成的方法存根
		super.endDocument();
		System.out.println("解析已经结束");
	}

	/**
	 * endElement函数:当解析完一个节点后会调用该函数,例如<name>数据</name>,解析到</name>节点后就调用该函数
	 * qName:节点的名字相当于DOM中的getNodeName()
	 */
	public void endElement(String uri, String localName, String qName)
			throws SAXException {
		// TODO 自动生成的方法存根
		super.endElement(uri, localName, qName);
		System.out.println(qName+"节点解析完成");
		cur=-1;
	}

	/**
	 * error:解析时遇到错误会调用改函数
	 */
	public void error(SAXParseException e) throws SAXException {
		// TODO 自动生成的方法存根
		super.error(e);
		System.out.println("解析出错");
	}

	/**
	 * 当开始解析文档时最先调用该函数,且只调用一次
	 */
	public void startDocument() throws SAXException {
		// TODO 自动生成的方法存根
		super.startDocument();
		System.out.println("解析已经开始");
	}

	/**
	 * startElement函数:当开始解析一个节点时会调用该函数,例如<name>数据</name>,解析到<name>节点后就调用该函数
	 */
	public void startElement(String uri, String localName, String qName,
			Attributes attributes) throws SAXException {
		// TODO 自动生成的方法存根
		super.startElement(uri, localName, qName, attributes);
		if(qName.equals("Books")){
			System.out.println("图书如下:");
			cur=0;
		}
		if(qName.equals("Book")){
			System.out.println("Book:");
			System.out.println(attributes.getLocalName(0)+":"+attributes.getValue(0));
			cur=1;
		}
		else if(qName.equals("name")){
			System.out.print("name:");
			cur=2;
		}
		else if(qName.equals("price")){
			System.out.print("price:");
			cur=3;
		}else{
			System.out.print("文本元素:");
			cur=4;
		}
	}

}
<pre class="java" name="code">	public static void SAX(File file){
		RSSHandler handler=new RSSHandler();
		SAXParserFactory factory=SAXParserFactory.newInstance();
		try {
			SAXParser paser=factory.newSAXParser();
			paser.parse(file, handler);
		} catch (ParserConfigurationException e) {
			// TODO 自动生成的 catch 块
			e.printStackTrace();
		} catch (SAXException e) {
			// TODO 自动生成的 catch 块
			e.printStackTrace();
		} catch (IOException e) {
			// TODO 自动生成的 catch 块
			e.printStackTrace();
		}
	}

 
<pre class="html" name="code"><?xml version="1.0" encoding="UTF-8"?>
<Books>textElement1
    <Book id="1">
        <name>Java Thinking</name>
        <price>100.0</price>
    </Book>
textElement2
    <Book id="2">
        <name>C++ Thinking</name>
        <price>200.0</price>
    </Book>
textElement3
</Books>

 
<pre class="plain" name="code">运行结果:(节点之外的数据没有处理例如<Books> <Book>之间的文本元素</Book> <Book>之间的文本元素,</Book> </Books>之间的文本元素)
解析已经开始
图书如下:
文本元素:Book:
id:1
name:Java Thinking  name节点解析完成
price:100.0  price节点解析完成
Book节点解析完成
Book:
id:2
name:C++ Thinking  name节点解析完成
price:200.0  price节点解析完成
Book节点解析完成
Books节点解析完成

解析已经结束

 


 

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Java中使用SAX解析XML,你可以按照以下步骤进行操作: 1. 导入相关的类和包,如`javax.xml.parsers.SAXParser`和`javax.xml.parsers.SAXParserFactory`。 2. 创建`SAXParserFactory`的实例。 3. 通过调用`SAXParserFactory`的`newSAXParser()`方法创建一个解析器。 4. 获取需要解析XML文档,并创建一个`File`对象来表示该文档。 5. 创建一个自定义的`SAXHandler`类,该类继承自`DefaultHandler`类,并重写需要的回调方法来处理XML元素和数据。 6. 调用解析器的`parse()`方法,传入文件和自定义的`SAXHandler`对象作为参数,开始解析XML文档。 你可以参考以下示例代码: ```java import java.io.File; import javax.xml.parsers.SAXParser; import javax.xml.parsers.SAXParserFactory; public class TestDemo { public static void main(String[] args) throws Exception { // 1.实例化SAXParserFactory对象 SAXParserFactory factory = SAXParserFactory.newInstance(); // 2.创建解析SAXParser parser = factory.newSAXParser(); // 3.获取需要解析的文档,生成解析器,最后解析文档 File f = new File("books.xml"); SaxHandler dh = new SaxHandler(); parser.parse(f, dh); } } ``` 请注意,上述代码中的`SaxHandler`是一个自定义的类,你需要根据自己的需求来实现该类,以便在解析XML时处理相应的元素和数据。 XML文档如下所示: ```xml <?xml version="1.0" encoding="UTF-8"?> <books> <book id="001"> <title>Harry Potter</title> <author>J K. Rowling</author> </book> <book id="002"> <title>Learning XML</title> <author>Erik T. Ray</author> </book> </books> ``` 希望以上信息能够帮到你。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [java中使用sax解析xml的解决方法](https://download.csdn.net/download/weixin_38747216/12815749)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [在java中使用sax解析xml](https://blog.csdn.net/weixin_33884611/article/details/86303531)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值