import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserFactory;
public class Demo01_Pull_Person {
public static void main(String[] args) throws Exception {
// 解析本地的person.xml
File f1 = new File("person.xml");
// step1:目测,观察:xml文件的格式,构建javabean类
// step2:
// 获取解析器的工厂类
XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
// 从工厂中获取解析器对象
XmlPullParser parser = factory.newPullParser();
// System.out.println("开始解析文档事件:XmlPullParser.START_DOCUMENT-->" +
// XmlPullParser.START_DOCUMENT);
// System.out.println("结束解析文档事件:XmlPullParser.END_DOCUMENT-->" +
// XmlPullParser.END_DOCUMENT);
// System.out.println("开始标签事件:XmlPullParser.START_TAG-->" +
// XmlPullParser.START_TAG);
// System.out.println("结束标签事件:XmlPullParser.END_TAG-->" +
// XmlPullParser.END_TAG);
// System.out.println("文本标签事件:XmlPullParser.TEXT-->" +
// XmlPullParser.TEXT);
// 设置解析器要扫描的文件
InputStream is = new FileInputStream(f1);
parser.setInput(is, "utf-8");
Person p = null;
List<Person> list = null;
// A:获取首次的事件类型
int eventType = parser.getEventType();
while (eventType != XmlPullParser.END_DOCUMENT) {
// 1.获取标签名
String tagName = parser.getName();
System.out.println("eventType:" + eventType + ",标签名:" + tagName);
// 2.分支:eventType
switch (eventType) {
case XmlPullParser.START_TAG:// 2开始标签事件
if ("persons".equals(tagName)) {
// 创建集合
list = new ArrayList<>();
} else if ("person".equals(tagName)) {
p = new Person();
// 属性
p.setId(parser.getAttributeValue(0));// 23.根据属性的下标,取到该属性的值
} else if ("name".equals(tagName)) {
String name = parser.nextText();// 张老师,
// 获取解析器的下一个文本,同时跳过对应的结束标签
p.setName(name);
} else if ("age".equals(tagName)) {
String age = parser.nextText();
p.setAge(Integer.parseInt(age));
}
break;
case XmlPullParser.END_TAG:// 3结束标签事件
if ("person".equals(tagName)) {
// 将p对象,存入集合
list.add(p);
}
break;
}
// 3.获取下次事件类型
eventType = parser.next();
}
// 遍历list集合取数据
for (int i = 0; i < list.size(); i++) {
System.out.println(list.get(i));
}
// debug
}
}
import java.io.FileInputStream;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserFactory;
public class Demo01_Pull_Person {
public static void main(String[] args) throws Exception {
// 解析本地的person.xml
File f1 = new File("person.xml");
// step1:目测,观察:xml文件的格式,构建javabean类
// step2:
// 获取解析器的工厂类
XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
// 从工厂中获取解析器对象
XmlPullParser parser = factory.newPullParser();
// System.out.println("开始解析文档事件:XmlPullParser.START_DOCUMENT-->" +
// XmlPullParser.START_DOCUMENT);
// System.out.println("结束解析文档事件:XmlPullParser.END_DOCUMENT-->" +
// XmlPullParser.END_DOCUMENT);
// System.out.println("开始标签事件:XmlPullParser.START_TAG-->" +
// XmlPullParser.START_TAG);
// System.out.println("结束标签事件:XmlPullParser.END_TAG-->" +
// XmlPullParser.END_TAG);
// System.out.println("文本标签事件:XmlPullParser.TEXT-->" +
// XmlPullParser.TEXT);
// 设置解析器要扫描的文件
InputStream is = new FileInputStream(f1);
parser.setInput(is, "utf-8");
Person p = null;
List<Person> list = null;
// A:获取首次的事件类型
int eventType = parser.getEventType();
while (eventType != XmlPullParser.END_DOCUMENT) {
// 1.获取标签名
String tagName = parser.getName();
System.out.println("eventType:" + eventType + ",标签名:" + tagName);
// 2.分支:eventType
switch (eventType) {
case XmlPullParser.START_TAG:// 2开始标签事件
if ("persons".equals(tagName)) {
// 创建集合
list = new ArrayList<>();
} else if ("person".equals(tagName)) {
p = new Person();
// 属性
p.setId(parser.getAttributeValue(0));// 23.根据属性的下标,取到该属性的值
} else if ("name".equals(tagName)) {
String name = parser.nextText();// 张老师,
// 获取解析器的下一个文本,同时跳过对应的结束标签
p.setName(name);
} else if ("age".equals(tagName)) {
String age = parser.nextText();
p.setAge(Integer.parseInt(age));
}
break;
case XmlPullParser.END_TAG:// 3结束标签事件
if ("person".equals(tagName)) {
// 将p对象,存入集合
list.add(p);
}
break;
}
// 3.获取下次事件类型
eventType = parser.next();
}
// 遍历list集合取数据
for (int i = 0; i < list.size(); i++) {
System.out.println(list.get(i));
}
// debug
}
}