一、本次总结用到的xml文本

1、    <?xml version="1.0" encoding="UTF-8" standalone="no"?>
        <!-- 引进dtd文件的标签 --><!-- <!DOCTYPE 书架 SYSTEM "book.dtd"> -->
        <书架>
            <书 ISBN="a" 出版社="人民出版社">
                <书名>三国演义</书名>
                <作者>罗贯中</作者>
                <批发价>500¥</批发价>
                <售价>100$</售价>
            </书>
            <书 ISBN="b" 出版社="人民出版社">
                <书名>西游记</书名>
                <作者>吴承恩</作者>
                <售价>55¥</售价>
            </书>
        </书架>
二、利用jaxp进行DOM的解析方法
    1、首先获得解析工厂DOcumentBuilderFactory
        javax.xml.parsers 类
        
        **DocumentBuilderFactory:定义工厂API,使应用程序能够从xml文档获取生成DOM对象的解析器。

DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
        
        **newInstance()方法:获取DocumentBuilderFactory的新实类。此static方法创建一个新的工厂实类。
    2、得到解析器DocumentBuilder
        类 DocumentBuilder
        **定义API,使其从xml文档中DOM文档实类。应用程序员可以从xml获取一个Document
        
        DocumentBuilder builder = factory.newDocumentBuilder();
        
        **newDocumentBuilder:使用当前配置的参数创建一个新的DocumentBuilder实类。
        
    3、解析制定的xml文档。得到代表内存的Dom树的Document对象
        
        Document document = builder.parse("src/book.xml");
        **builder.parse()方法:将给定输入源的内容解析为一个xml文档。并返回一个新的DOM document对象

三、得到某个具体节点的内容:列如:打印第二本书的作者
    1、根据标签的内容获取所有的作者名称
        NodeList nodelist=document.getElementsBytagName()
        NodeList:接口提供对节点的有序集合的抽象
    2、按照索引获取第二个作者元素
        Node node=nodelist.item(1);
    3、打印该元素的文本
        String text=node.getTextContent();
        System.out.println(text);
四、遍历所有的元素节点:打印元素的节点名称
    1、判断当前节点是否为一个元素节点
        short nd=node.getNodeType();
        if(nd==Node.ELEMENT_NODE){
        如果是:打印元素节点的名称
        system.out.println(node.getNodeName());
        }
        如果不是找到他们的孩子节点
        NodeList nodelist=node.getChildNodes();
        int length=nodelist.getLength();//获取孩子节点的长度
        for(int 1=0;i<length;i++){
        //遍历孩子节点进行递归
        Node n=nodelist.item(i);
        test2(n);
        }
五、修改元素节点的主题内容
    1、列如:找到第一本书的售价
        NodeList nodelist = docuement.getElementsByTagName("售价");
    2、设置其主题内容
        Node no=nodelist.item(0);//得到他的节点
        no.setTextContent("100$");//设置他的主题内容
    3、把内存中的document树写回到xml中
        TransformerFactory  factory = TransformerTactory.newInstance();
        Transformer tr = factory.newTransformer();
        tr.transformer(new DOMSource(doument),new StreamResult("src/book.xml"));
六、向指定元素节点中增加子元素节点
    1、创建一个新元素并设置其内容
        Element element = Element.createElement("内部价");
        设置他的文本内容
        element.setTexstContent("300$");
    2、找到第一本书
        NodeList nodelist = document.getElementsByTagName("书");
        Node first =nodelist.item(0);
    3、把新节点挂到第一本书上
        first.appendChild(element)
    4、把内存中的document树写会到xml中
        TransformerFactory factory = TransformerFactory.newInstace();
        Transformer tr=factory.newTransformer();
        tr.transformer(new DOMSource(document),new StreamResult("src/book.xml"));
七、向指定的元素节点上增加同级元素节点:列如:在第一本书的售价前面添加批发价
    1、创建并设置其主题内容
        Element element = documcnet.createElement("批发价");
        element.setTextContent("500$");
    2、找到第一本书的售价
        NodeList nodelist = document.getElementsByTagName("售价");
        Node node=nodelist.item(0);
     3、在售价的前面添加新建的元素:
        ***增加子节点,一定要使用父元素进行
        node.getParentNode().insertBefore(element,node);
    4、把内存中的document树写回到xml中
        TransformerFactory factory = TransformerFactory.newInstance();
        Transformer tr = factory.newTransformer()
        tr.transformer(new DOMSource(document),new StreamResult("src/book.xml"));
八、删除指定元素的节点
    1、删除子节点需要父节点进行删除
        列如:找到内部价进行删除
        NodeList nodelist = document.getElementsByTagName("内部价");
         Node node = nodelist.item(0);
         node.getPraentNode().removeChhild(n);
    2、把内存的document树写回到xml中
        TransformerFactory factory=TransformerFactory.newInstance();
        Transformer tr=factory.Transformer();
        tr.transformer(new DOMSource(document),new StreamResult("src/book.xml"));
九、操作xml元素属性:打印第一本书的出版社
    1、首先得到第一本
        Node node = document.getElementsByTagName("书").item(0);
    2、打印指定属性的值
        Element e = (Element)n;
        system.out.println(e.getAttribute("出版社"));

Document树的解析方法的更多相关文章

  1. XML解析之DOM详解及与SAX解析方法的比较

    XML解析(DOM) XML文件解析方法介绍 我们所用到的NSXMLParser是采用SAX方法解析 SAX(Simple API for XML) 只能读,不能修改,只能顺序访问,适合解析大型XML ...

  2. 八、Android学习第七天——XML文件解析方法(转)

    (转自:http://wenku.baidu.com/view/af39b3164431b90d6c85c72f.html) 八.Android学习第七天——XML文件解析方法 XML文件:exten ...

  3. XML的四种解析方法

    转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/6646572.html  XML文档以层级标签的形式来组织数据,多用于配置文件.存储静态数据.交换数据.     ...

  4. XML 的解析方法

    四种XML解析方法: (1)Dom生成和解析XML文档 *解析器读入整个文档,然后构建一个驻留内存的树结构,然后代码就可以使用 DOM 接口来操作这个树结构.     * 优点:整个文档树在内存中,便 ...

  5. document的属性与方法小结

    document节点是文档的根节点,每张网页都有自己的document节点.属性:1:document.doctype----它是一个对象,包含了当前文档类型 (Document Type Decla ...

  6. Atitit.sql ast 表达式 语法树 语法 解析原理与实现 java php c#.net js python

    Atitit.sql ast 表达式 语法树 语法 解析原理与实现 java php c#.net js python 1.1. Sql语法树 ast 如下图锁死1 2. SQL语句解析的思路和过程3 ...

  7. C#使用表达式树动态调用方法并实现99乘法表

    我们在使用C#编程的时候,经常使用反射来动态调用方法,但有时候需要动态的生成方法,下面介绍使用表达式树的方式来自动生成方法,并调用. 首先需要说明什么是表达式,熟悉Linq的程序猿都用过类似于下面的代 ...

  8. linux设备驱动程序-i2c(2)-adapter和设备树的解析

    linux设备驱动程序-i2c(2)-adapter和设备树的解析 (注: 基于beagle bone green开发板,linux4.14内核版本) 在本系列linux内核i2c框架的前两篇,分别讲 ...

  9. 逗号分割符--字段中含逗号等情况的解析方法Java实现

    最近在处理文本字符串时,没一行数据都是按照逗号分割的,每个字段值一般情况是带有双引号的,但是有的字段值里面还包含逗号,甚至有的字段就没有双引号,这个分割起来就有点麻烦了 下面说一下我解决方法,如果谁有 ...

随机推荐

  1. js初学者的div移动

    <!DOCTYPE HTML> <html lang="en-US"> <head> <meta charset="UTF-8& ...

  2. sublime_markdown

    sublime text 下实现markdown实时预览 这个文档是网上比较流行的教程,你可以按照这个教程来,如果你幸运的话,也许一次性成功.那就到此为止,可以不用看了-- ---------–华丽的 ...

  3. 使用 MySQL 查找附近的位置

    使用 MySQL 查找附近的位置 以下 SQL 语句将会在与坐标 37, -122 相距 25 英里的半径范围内查找最近的 20 个位置.该语句根据行的纬度/经度以及目标纬度/经度计算距离,然后只请求 ...

  4. 项目中踩过的坑之-sessionStorage

    总想写点什么,却不知道从何写起,那就从项目中踩过的坑开始吧,希望能给可能碰到相同问题的小伙伴一点帮助. 项目情景: 有一个id,要求通过当前网页打开一个新页面(不是当前页面),并把id传给打开的新页面 ...

  5. Java特性-动态代理

    代理在开发中无处不在: 我们完成一个接口开发A,接口下有很多个实现类,这些类有些共同要处理的部分,比如每一个类都定义了接口A中的方法getXX(String name).我现在想把每次调用某个实现类的 ...

  6. 同上 遍历obj的值 来定义当前的后台数据在页面的定位

    function getlistRoom(obj) { //obj就是通过ajax传过来的 data for (var i = 0; i < obj.length; i++) {//遍历数据 v ...

  7. hightchart属性(更新中...)

    legend:{ layout: 'vertical', //legend中内容垂直放置 align: 'right', //放在图表右边 verticalAlign: 'middle',    // ...

  8. Outlook查找未读邮件

    1.查找新邮件的未读邮件,可以在下图中查找 2.恢复已删除邮件,如果邮件是未读邮件,在上图中是查找不到,只能通过视图去查找 步骤2内容摘自百度

  9. firefox vimperator插件

    firefox vimperator插件实在是强大,最喜欢的几个功能做个笔记. 如何复制网页上的文字:c进入caret模式,定位cursor到要复制的开始位置--v进入visual模式,用hjkl键选 ...

  10. WPF与WinForm开发有什么区别?

    转自http://hi.baidu.com/leoliu83/blog/item/1d1a4a66dcb41134aa184cfd.html WPF开发于WinForm之后,从技术发展的角度,WPF比 ...