Android中使用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();
writexml(persons, writer);
string content = writer.tostring();
案例:
123.xml
<?xml version='1.0' encoding='utf-8' standalone='yes' ?>
<persons>
<person id="1">
<name>zhangsan</name>
<age>12</age>
</person>
<person id="2">
<name>lisi</name>
<age>34</age>
</person>
</persons>
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
* @param writer
* @return
*/
public 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文件
*
* @param instream
* @return
* @throws exception
*/
public 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元素,即返回它的值
} else if (name.equalsignorecase("age")) {
currentperson.setage(new short(parser.nexttext()));
}
}
break;
case xmlpullparser.end_tag:// 结束元素事件
if (parser.getname().equalsignorecase("person")&& currentperson != null) {
persons.add(currentperson);
currentperson = null;
}
break;
}
eventtype = parser.next();
}
instream.close();
return persons;
}
}
pullpersonservicetest pull解析器测试类
package com.ljq.test;
import java.io.bufferedwriter;
import java.io.fileoutputstream;
import java.io.inputstream;
import java.io.outputstreamwriter;
import java.util.arraylist;
import java.util.list;
import com.ljq.entity.person;
import com.ljq.service.pullpersonservice;
import android.content.context;
import android.test.androidtestcase;
import android.util.log;
public class pullpersonservicetest extends androidtestcase{
private final string tag = "pullpersonservicetest";
/**
* 使用pull解析器解析xml文件
*
* @throws exception
*/
public void testreadxml() throws exception{
//inputstream inputstream = pullpersonservicetest.class.getclassloader().getresourceasstream("ljq.xml");
inputstream inputstream= this.getcontext().openfileinput("123.xml");
list<person> persons = pullpersonservice.readxml(inputstream);
for(person person : persons){
log.i(tag, person.getid() + " : " + person.getname() + " : " + person.getage());
}
}
/**
* 使用pull解析器生成xml文件
*
* @throws exception
*/
public void testwritexml() throws exception{
fileoutputstream fileoutputstream = this.getcontext().openfileoutput("123.xml", context.mode_private);
outputstreamwriter outstreamwriter = new outputstreamwriter(fileoutputstream, "utf-8");
list<person> persons = new arraylist<person>();
persons.add(new person(1, "zhangsan", (short)12));
persons.add(new person(2, "lisi", (short)34));
bufferedwriter writer = new bufferedwriter(outstreamwriter);
string string = pullpersonservice.writexml(persons, writer);
log.i(tag, string.tostring());
}
}
推荐阅读
-
Android中使用pull解析器操作xml文件的解决办法
-
Android 使用Pull方法解析XML文件的方法
-
Android编程使用pull方式解析xml格式文件的方法详解
-
SQLSERVER 2005中使用sql语句对xml文件和其数据的进行操作(很全面)
-
Android EditText设置Filter以后(xml布局文件中maxLength不起作用的解决办法)
-
Android编程使用pull方式解析xml格式文件的方法详解
-
SQLSERVER 2005中使用sql语句对xml文件和其数据的进行操作(很全
-
SQLSERVER 2005中使用sql语句对xml文件和其数据的进行操作(很全面)
-
Android EditText设置Filter以后(xml布局文件中maxLength不起作用的解决办法)