1、person.xml
<?xml version="1.0" encoding="UTF-8"?> <persons> <person id="001"> <name>张三</name> <sex>男</sex> <age>23</age> </person> <person id="002"> <name>梅超风</name> <sex>女</sex> <age>22</age> </person> </persons>
2、PersonService.java
package com.webyun.app.service; import java.io.InputStream; import java.io.OutputStream; import java.util.ArrayList; import java.util.List; import org.xmlpull.v1.XmlPullParser; import org.xmlpull.v1.XmlSerializer; import android.util.Xml; import com.webyun.app.domain.Person; public class PersonService { /** * 获取数据 * @param inputStream * @return * @throws Exception */ public static List<Person> getPersons(InputStream inputStream) throws Exception { List<Person> persons = null; Person person = null; //通过Android帮助类获取Pull解析器 XmlPullParser pullParser = Xml.newPullParser(); //为Pull解析器设置需要解析的XML数据 pullParser.setInput(inputStream, "UTF-8"); int eventType = pullParser.getEventType(); while(eventType != XmlPullParser.END_DOCUMENT){ switch(eventType){ case XmlPullParser.START_DOCUMENT: persons = new ArrayList<Person>(); break; case XmlPullParser.START_TAG: if("person".equals(pullParser.getName())){ person = new Person(); String id = pullParser.getAttributeValue(0); person.setId(id); } if("name".equals(pullParser.getName())){ String name = pullParser.nextText(); person.setName(name); } if("sex".equals(pullParser.getName())){ String sex = pullParser.nextText(); person.setSex(sex); } if("age".equals(pullParser.getName())){ int age = new Integer(pullParser.nextText()); person.setAge(age); } break; case XmlPullParser.END_TAG: if("person".equals(pullParser.getName())){ persons.add(person); person = null; } break; } eventType = pullParser.next(); } return persons; } /** * 保存数据 * @param persons 数据 * @param os 输出方向 * @throws Exception */ public static void save(List<Person> persons, OutputStream os) throws Exception { XmlSerializer serializer = Xml.newSerializer(); serializer.setOutput(os, "UTF-8"); //开始文档 serializer.startDocument("UTF-8", true); serializer.startTag(null, "persons"); for(Person person : persons){ serializer.startTag(null, "person"); serializer.attribute(null, "id", person.getId().toString()); serializer.startTag(null, "name"); serializer.text(person.getName()); serializer.endTag(null, "name"); serializer.startTag(null, "sex"); serializer.text(person.getSex()); serializer.endTag(null, "sex"); serializer.startTag(null, "age"); serializer.text(person.getAge().toString()); serializer.endTag(null, "age"); serializer.endTag(null, "person"); } serializer.endTag(null, "persons"); //结束文档 serializer.endDocument(); os.flush(); os.close(); } }
3、PersonServiceTest.java
package com.webyun.app.test; import java.io.InputStream; import java.util.ArrayList; import java.util.List; import android.test.AndroidTestCase; import android.util.Log; import com.webyun.app.domain.Person; import com.webyun.app.service.PersonService; public class PersonServiceTest extends AndroidTestCase { private static final String TAG = "PersonServiceTest"; public void testPersons() throws Exception { InputStream inputStream = this.getClass().getClassLoader().getResourceAsStream("person.xml"); List<Person> persons = PersonService.getPersons(inputStream); for(Person person :persons){ Log.i(TAG, person.toString()); } } public void testSave() throws Exception { List<Person> persons = new ArrayList<Person>(); persons.add(new Person("003","李四","男",25)); persons.add(new Person("004","大雄","男",22)); persons.add(new Person("005","豆豆","女",20)); PersonService.save(persons, System.out); } }
相关推荐
总的来说,使用Pull解析器读取和生成XML文件是一种高效且灵活的方法,尤其适合处理大型XML文档。通过掌握这一技术,开发者可以更好地处理XML数据,提高程序的性能和稳定性。在进行XML操作时,还需注意数据的正确性和...
XML(eXtensible Markup Language)是一种用于标记数据的语言,广泛应用于数据交换、配置文件以及文档存储等领域。在Android开发中,由于其轻量级和高效的...在实践中不断探索和优化,你将能够更好地驾驭XML数据处理。
XML Pull解析器在Android开发中广泛使用,尤其是在处理大型XML文件或实时数据流时,其效率和低内存占用是关键优势。掌握XML Pull解析和生成技术对于Android开发者来说是必备技能之一,能够提高应用的性能和用户体验...
PULL解析器同样逐行读取XML,但开发者需要主动调用next方法前进到下一个事件。这种方式易于理解和实现,适合简单的XML结构。在解析天气预报XML时,我们首先需要创建PullParser对象,然后通过nextTag()方法遍历XML,...
在Android开发中,由于其轻量级和低内存占用,Pull解析器常常被用来解析XML文档,尤其是在处理大数据量时,相比DOM和SAX解析器更为高效。 Pull解析器是一种事件驱动的解析方式,它不会一次性加载整个XML文档到内存...
在处理大量XML数据时,Pull解析器的事件驱动模型可以显著提高应用程序的性能,因为它不需要一次性加载整个XML文档到内存中。对于Android应用开发人员来说,熟练掌握Pull解析器的使用技巧,将有助于提升应用程序的...
XML(eXtensible Markup Language)是一种用于标记数据的语言,广泛应用于Android开发中,用于存储配置、布局等信息。在Android系统中,XML Pull解析是一种...在实际开发中,熟练掌握这一技术对于处理XML数据至关重要。
我们将讲解如何使用Pull解析器读取本地XML文件,并生成一个新的、格式不同的XML文件。 Pull解析是一种事件驱动的解析方法,它不像DOM解析那样将整个XML文档加载到内存中,而是按需逐个处理XML元素。这种方法节省了...
在Android开发中,XML是一种常见的数据格式,用于存储和传输数据。...理解并熟练掌握XML PULL解析器对于Android开发者来说是非常重要的,因为它可以帮助你在资源有限的移动设备上有效地处理XML数据。
在Android开发中,处理XML数据是一项常见的任务,而Android提供了内置的Pull解析器来高效地读取和生成XML文件。本文将详细介绍如何使用Pull解析器来操作XML。 首先,我们来理解什么是Pull解析器。Pull解析器是一种...
XML(eXtensible Markup Language)是一种用于标记数据的语言,广泛应用于数据交换、配置文件以及文档结构化存储等领域。...通过观看和跟随教程,相信你将能够快速上手并熟练运用XML Pull解析器进行XML数据的处理。
在Android开发中,XML...通过创建Pull解析器实例,监听XML事件,以及适当优化,开发者可以轻松处理XML数据,实现更流畅的用户体验。在实际开发中,结合具体的业务场景灵活运用,能够大大提高应用程序的性能和稳定性。
首先,理解XML Pull解析器的工作原理是至关重要的。在Android中,XML Pull解析是一种轻量级处理XML文档的方式,它允许应用移动通过XML文档的结构,而无需预先加载整个文档到内存。这使得解析大型XML文件成为可能,...
本文将详细介绍如何使用Pull解析器来处理XML数据,并结合Junit进行测试,确保解析和生成XML文件的正确性。 首先,让我们理解什么是Pull解析器。与DOM(Document Object Model)和SAX(Simple API for XML)不同,...
总结,Android中的Pull解析器是处理XML数据的有效工具,它适合读取大文件且内存效率高。而通过`XmlSerializer`,我们可以方便地生成XML内容。在实际项目中,结合这两种技术,开发者可以轻松地进行XML数据的读取和...
在这个例子中,开发者通常会利用Android的Pull解析器来处理XML数据,从而获取并显示天气预报信息。以下是这个主题涵盖的一些关键知识点: 1. **Android网络请求**:首先,你需要了解如何在Android应用中进行网络...
总的来说,PULL解析器是Android开发中处理XML数据的有效工具,它提供了轻量级、高效的方式,适合处理大型或频繁更新的XML数据。通过理解PULL解析的工作原理和使用方法,开发者可以更好地优化应用性能,提高用户体验...
为了有效地处理XML文档,Android提供了多种解析机制,其中一种就是Pull解析器(PULL Parser)。本篇将深入探讨Android下Pull解析器的使用,以及如何利用它来解析和生成XML文件。 一、Android Pull解析器简介 Pull...
PullXML解析器是Android系统提供的一种轻量级的XML解析方法,它适用于处理大量的XML数据,特别是当内存有限或需要高效处理流式数据时。本文将深入探讨如何使用PullXML解析本地XML数据,并将解析后的数据存回本地。 ...
"Pull解析XML"是Android系统中处理XML文档的一种高效方法,相较于DOM(Document Object Model)和SAX(Simple API for XML),Pull解析器在内存占用和性能上有显著优势,尤其适合于移动设备资源有限的环境。...