使用pull解析器操作xml文件

前端之家收集整理的这篇文章主要介绍了使用pull解析器操作xml文件前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

一、使用Pull解析器读取XML文件

除了可以使用SAX或DOM解析XML文件之外,大家也可以使用Android内置的Pull解析器解析XML文件Pull解析器是一个开源的java项目,既可以用于android,也可以用于JavaEE。如果用在javaEE需要把其jar文件放入类路径中,因为Android已经集成进了Pull解析器,所以无需添加任何jar文件。android系统本身使用到的各种xml文件,其内部也是采用Pull解析器进行解析的。 Pull解析器的运行方式与SAX 解析器相似。它提供了类似的事件,如:开始元素和结束元素事件,使用parser.next()可以进入下一个元素并触发相应事件。跟SAX不同的是, Pull解析器产生的事件是一个数字,而非方法,因此可以使用一个switch对感兴趣的事件进行处理。当元素开始解析时,调用parser.nextText()方法可以获取下一个Text类型节点的值

二、使用Pull解析器生成XML文件

有些时候,我们需要生成一个XML文件生成XML文件方法有很多,如:可以只使用一个StringBuilder组拼XML内容,然后把内容写入到文件中;或者使用DOM API生成XML文件,或者也可以使用pull解析器生成XML文件这里推荐大家使用Pull解析器。

使用Pull解析器生成一个与ljq.xml文件内容相同的myljq.xml文件代码在本页下方备注

使用代码如下(生成XML文件):

File xmlFile = new File("myljq.xml");

FileOutputStream outStream = new FileOutputStream(xmlFile);

OutputStreamWriter outStreamWriter = new OutputStreamWriter(outStream,"UTF-8");

BufferedWriter writer = new BufferedWriter(outStreamWriter);

writeXML(persons,writer);

writer.flush();

writer.close();

如果只想得到生成的xml字符串内容,可以使用StringWriter:

StringWriter writer = new StringWriter();

String content = writer.toString();

案例:

123.xml

  
  
<? xml version='1.0' encoding='UTF-8' standalone='yes' ?> < persons > person id ="1" name > zhangsan </ age > 12 person ="2" > lisi > 34 >

PullPersonService pull解析器操作类

package com.ljq.service; import java.io.InputStream; import java.io.Writer; import java.util.ArrayList; import java.util.List; import org.xmlpull.v1.XmlPullParser; import org.xmlpull.v1.XmlSerializer; import com.ljq.entity.Person; import android.util.Xml; /** * Pull解析xml文件 * * @author jiqinlin * */ public class PullPersonService { * 使用pull解析器生成xml文件 * * @param persons * writer * @return static String writeXML(List < Person > persons,Writer writer){ XmlSerializer serializer = Xml.newSerializer(); try { serializer.setOutput(writer); serializer.startDocument( " UTF-8 " , true ); // 第一个参数为命名空间,如果不使用命名空间,可以设置为null serializer.startTag( "" , " persons " ); for (Person person : persons){ serializer.startTag( "" , " person " ); serializer.attribute( "" , " id " ,person.getId().toString()); serializer.startTag( "" , " name " ); serializer.text(person.getName()); serializer.endTag( "" , " name " ); serializer.startTag( "" , " age " ); serializer.text(person.getAge().toString()); serializer.endTag( "" , " age " ); serializer.endTag( "" , " person " ); } serializer.endTag( "" , " persons " ); serializer.endDocument(); } catch (Exception e) { e.printStackTrace(); } return writer.toString(); } * 使用pull解析器解析xml文件 * * inStream * * @throws Exception static List < Person > readXML(InputStream inStream) throws Exception { XmlPullParser parser = Xml.newPullParser(); parser.setInput(inStream, " UTF-8 " ); int eventType = parser.getEventType(); Person currentPerson = null ; List < Person > persons = null ; while (eventType != XmlPullParser.END_DOCUMENT) { switch (eventType) { case XmlPullParser.START_DOCUMENT: 文档开始事件,可以进行数据初始化处理 persons = new ArrayList < Person > (); break ; case XmlPullParser.START_TAG: 开始元素事件 String name = parser.getName(); if (name.equalsIgnoreCase( " person " )) { currentPerson = new Person(); currentPerson.setId( new Integer(parser.getAttributeValue( null , " id " ))); } else if (currentPerson != null ) { if (name.equalsIgnoreCase( " name " )) { currentPerson.setName(parser.nextText()); 如果后面是Text元素,即返回它的值 } if (name.equalsIgnoreCase( " age " )) { currentPerson.setAge( new Short(parser.nextText())); } } case XmlPullParser.END_TAG: 结束元素事件 if (parser.getName().equalsIgnoreCase( " person " ) && currentPerson != null ) { persons.add(currentPerson); currentPerson = null ; } break ; } eventType = parser.next(); } inStream.close(); return persons; } }

猜你在找的XML相关文章