使用xmlpullparser解析xml数据,先获取实例并设置输入源,通过循环读取事件类型,在start_tag、text和end_tag中处理标签与文本,利用kotlin数据类构建book列表,最终返回解析结果。

在Android开发中,解析XML数据是常见的需求,比如处理网络接口返回的XML、读取本地配置文件等。Kotlin作为Android官方推荐语言,结合XmlPullParser可以高效地完成这项任务。XmlPullParser是一种轻量级、事件驱动的XML解析器,在Android平台原生支持,性能良好且内存占用低。
使用XmlPullParser的基本流程
XmlPullParser采用“事件驱动”方式解析XML,即逐行读取并触发对应事件(如开始标签、结束标签、文本内容等)。你需要监听这些事件,并根据当前状态提取所需数据。
基本步骤如下:
- 获取
XmlPullParser实例,通常通过Xml.newPullParser() - 将XML数据源(InputStream或Reader)传给解析器
- 循环调用
next()方法遍历事件 - 在循环中判断事件类型,提取数据
- 遇到起始标签时读取属性或准备收集内容,结束标签时保存对象
定义数据模型类
假设我们有如下结构的XML:
可创建对应的Kotlin数据类:
data class Book(
val id: String,
val title: String,
val author: String
)
实现XML解析逻辑
以下是在Activity或工具类中使用XmlPullParser解析上述XML的完整示例:
import android.util.Xml
import org.xmlpull.v1.XmlPullParser
import java.io.InputStream
fun parseBooks(inputStream: InputStream): List<Book> {
val parser = Xml.newPullParser()
parser.setFeature(XmlPullParser.FEATURE_PROCESS_NAMESPACES, false)
parser.setInput(inputStream, null)
var eventType = parser.eventType
var currentBook: Book? = null
var currentText = ""
val books = mutableListOf<Book>()
while (eventType != XmlPullParser.END_DOCUMENT) {
val name = parser.name
when (eventType) {
XmlPullParser.START_TAG -> {
if (name == "book") {
val id = parser.getAttributeValue(null, "id")
currentBook = Book(id = id, title = "", author = "")
}
}
XmlPullParser.TEXT -> {
currentText = parser.text
}
XmlPullParser.END_TAG -> {
when (name) {
"title" -> currentBook?.let { it.copy(title = currentText).also { currentBook = it } }
"author" -> currentBook?.let { it.copy(author = currentText).also { currentBook = it } }
"book" -> currentBook?.let { books.add(it) }
}
}
}
eventType = parser.next()
}
return books
}
注意:由于Book是不可变数据类,我们在设置字段时使用了copy()方式临时更新值。
在Activity中调用解析方法
如果XML文件放在res/raw/books.xml,可以在Activity中这样加载:
val inputStream = resources.openRawResource(R.raw.books)
val books = parseBooks(inputStream)
inputStream.close()
// 打印结果测试
books.forEach { Log.d("XMLParser", it.toString()) }
如果是从网络获取的输入流,直接传入即可,但记得在子线程中执行,避免阻塞主线程。
基本上就这些。XmlPullParser虽然不像SAX那样复杂,也不像DOM那样占用内存,适合在移动端使用。配合Kotlin简洁的语法,能快速实现稳定可靠的XML解析功能。










