美文网首页我爱编程
xml常用解析方式.上(相应api的基本用法)

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

作者: yuewe | 来源:发表于2017-07-14 14:40 被阅读0次

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

    相关文章

      网友评论

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

        本文链接:https://www.haomeiwen.com/subject/cnenhxtx.html