一、使用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文件的解决办法所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)