Android中使用pull解析器操作xml文件的解决办法

2016-02-19 10:05 5 1 收藏

今天图老师小编给大家精心推荐个Android中使用pull解析器操作xml文件的解决办法教程,一起来看看过程究竟如何进行吧!喜欢还请点个赞哦~

【 tulaoshi.com - 编程语言 】

一、使用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);

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

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"
    namezhangsan/name
    age12/age
  /person
  person id="2"
    namelisi/name
    age34/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;

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

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(ListPerson 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 ListPerson readXML(InputStream inStream) throws Exception {
        XmlPullParser parser = Xml.newPullParser();
        parser.setInput(inStream, "UTF-8");
        int eventType = parser.getEventType();
        Person currentPerson = null;
        ListPerson persons = null;
        while (eventType != XmlPullParser.END_DOCUMENT) {
            switch (eventType) {
            case XmlPullParser.START_DOCUMENT:// 文档开始事件,可以进行数据初始化处理
                persons = new ArrayListPerson();
                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");
        ListPerson 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");
        ListPerson persons = new ArrayListPerson();
        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());
    }
}

来源:https://www.tulaoshi.com/n/20160219/1593289.html

延伸阅读
手机QQ浏览器视频解析异常解决办法   手机QQ浏览器视频解析异常解决办法 1、首先进入浏览器,点击正下方三条杠的标志 2、接下来会有一个菜单界面,点击设置 3、然后一直向下翻,找到关于与反馈,这个在最下面 4、然后会进入这一栏,接着点击版本 5、它会检查更新,然后会提示你是否下载最...
标签: 电脑入门
      一般大部分人在Win 7/Vista共享文件为了方便都去掉了密码保护的共享。这样在共享文件夹时就需要添加Everyone或Guest权限。一般共享文件夹时是以向导的形式,添加用户设置权限都很简单,不会有问题。但看到一些人共享驱动器时却遇到了问题。就是网上邻居能够看到共享的驱动器,访问却提示没有权限。由于共享驱动...
标签: Web开发
MagpieRSS是一个不错的RSS抓取/解析工具,我本来打算自己写一个php的RSS解析工具,不过试了一下MagpieRSS,觉得还不错,能满足需要。 顺便看了看代码,记点笔记。 1.乱码问题 MagpieRSS过去时常出现乱码问题,从0.7版本解决了这个问题 Version0.7 support for input and output charset encoding based on t...
提示: org.xmlpull.v1.XmlPullParserException: PI must not start with xml (position:unknown @1:5 in java.io.InputStreamReader@47ec2770) org.xml.sax.SAXParseException: PI must not start with xml (position:unknown xm@3:5 in java.io.InputStreamReader@43e4b480) 经过多次查找确认XML语法没错误。 问题...
使用xmlspy编写xsl文件时候,当使用如下编码时,在xsl解释xml文件的时候总是使用UTF-16编码方式: 1. xsl文件: //这里虽然指明了显示编码,但是xmlspy生成的xsl解释文件会另在此行之前加上utf-16的编码方式而另此处的指示无效,解决办法如下: 2. xsl解释xml文件后输出文件的源代码: 3. 解决办法:把xsl文件改写...

经验教程

166

收藏

50
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部