方式一:Dom解析(Java中使用)
直接把整个xml文档的内容读到内存中,读取的文本内容被组成一个树形的结构,称为dom树。
则整个文本内容有不同的节点(Node)组成。通过查看api可知,Node是一个接口,节点有不同的类型,Attr,Element,Document都是常见的节点。
Dom解析xml的基本用法如下:
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document document = builder.parse("books.xml"); //books.xml是放在项目根目录,如果是其他目录,路径要更换。
NodeList list = document.getElementsByTagName("作者");
Node node = list.item(1);
System.out.println(node.getTextContent());//输出标签内的文本内容
修改Dom树内容,并写入到磁盘,业务代码如下:
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document document = builder.parse("books.xml");
NodeList list = document.getElementsByTagName("售价");
Node node = list.item(1);
node.setTextContent("99.00元"); //修改标签节点的内容。
TransformerFactory transformerFactory = TransformerFactory.newInstance();
Transformer transformer = transformerFactory.newTransformer();
Source source =newDOMSource(document);
Result result =newStreamResult("books.xml");
transformer.transform(source, result);
books.xml的内容如下:
<书架>
<书>
<书名>android开发实录
<作者>yuewe
<售价>39.00元
<书>
<书名>Java web开发实录
<作者>yuewe
<售价>99.00元
方式二:Sax解析(Java中使用)
Sax解析是边读边解析,要注意的是解析的顺序,在读到结束标签的时候,下一个读到往往是标签内容而不是开始标签。Sax解析的逻辑是通过实现一个ContentHandler里面相应的方法(处理的逻辑写在相应的方法里面)并设置给XMLReader来实现的。
业务代码如下:
SAXParserFactory saxParserFactory = SAXParserFactory.newInstance();
SAXParser saxParser = saxParserFactory.newSAXParser();
XMLReader reader = saxParser.getXMLReader();
reader.setContentHandler(newDefaultHandler() {
booleanisshow=false;
@Override
public voidstartElement(String uri, String localName, String qName, Attributes attributes)throwsSAXException {
if(qName.equals("售价")) {
isshow=true;
}
}
@Override
public voidendElement(String uri, String localName, String qName)throwsSAXException {
if(qName.equals("售价")) {
isshow=false;
}
}
@Override
public voidcharacters(char[] ch,intstart,intlength)throwsSAXException {
if(isshow) {
String content =newString(ch, start, length);
System.out.println(content);
}
}
});
reader.parse("books.xml");
方式三:Pull解析(Android主要使用)
pull解析主要是用于Android上,Java上也要用的话,要添加相应的jar包。pull解析与sax解析相似,但是用法有点不一样。而且sax解析一开始就要解析到末尾,而pull解析则是通过调用xmlPullParser.next()方法来解析下一部分(这里不是太清楚,以后有空测试是不是一次next解析一行)。
直接上代码:
XmlPullParserFactory xmlPullParserFactory = XmlPullParserFactory.newInstance();
XmlPullParser xmlPullParser = xmlPullParserFactory.newPullParser();
xmlPullParser.setInput(newFileInputStream(newFile("books.xml")),"utf-8");
inttype = xmlPullParser.getEventType();
List books =newArrayList<>();
Book b =null;
while(type != XmlPullParser.END_DOCUMENT) {
switch(type) {
caseXmlPullParser.START_TAG:
if(xmlPullParser.getName().equals("书名")) {
b.setTitle(xmlPullParser.nextText());
}else if(xmlPullParser.getName().equals("书")) {
b =newBook();
}else if(xmlPullParser.getName().equals("作者")) {
b.setAuthor(xmlPullParser.nextText());
}else if(xmlPullParser.getName().equals("售价")) {
b.setPrice(xmlPullParser.nextText());
}
;
break;
caseXmlPullParser.END_TAG:
if(xmlPullParser.getName().equals("书")) {
books.add(b);
}
;
break;
}
type = xmlPullParser.next();
}
for(Book book : books) {
System.out.println(book);
}
}
总结:考虑到一些应用场景和一些限制,Android端基本用的都是自带带的pull解析,而dom解析一次把数据读取到内存中,很耗内存。而Android系统给每个应用分配的内存是固定的,虽然可以通过添加多进程的方式添加内存,但这也提高了难度,所以Android端使用sax或pull解析xml比较合适,但就是不能修改文件。
本文是作者通过学习Android黑马视频做的一些笔记,侵删,邮箱号m13978575424@163.com。