xml常用解析方式.上(相应api的基本用法)

方式一: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。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1 XML解析No29 【 XML:可拓展标记语言,语言和HTML类似,也是一种标记语言。 特点:标记是自定义...
    征程_Journey阅读 1,684评论 0 9
  • 一、iOS 4种JSON数据解析方法详解 2013年09月10日⁄ 综合⁄ 共 9124字⁄ 字号小中大⁄评论关闭...
    lilinjianshu阅读 2,100评论 0 2
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,780评论 18 399
  • 一、绪论 上周工作需要了解项目的一些大体内容,结果在xml解析这一块看的迷迷糊糊的,所以在这里把学习到xm...
    cao健强阅读 4,115评论 1 7
  • 看完The Horse Dealer's Daughter ,想起老友记暗恋的复杂心情(瑞秋to乔伊) 明明很在意...
    去社阅读 289评论 1 0