欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

JAVA DOM解析XML文件过程详解

程序员文章站 2023-01-25 18:54:33
这篇文章主要介绍了java dom解析xml文件过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 代码如下 imp...

这篇文章主要介绍了java dom解析xml文件过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

代码如下

import java.io.ioexception;
import javax.xml.parsers.*;
import org.w3c.dom.document;
import org.w3c.dom.element;
import org.w3c.dom.namednodemap;
import org.w3c.dom.node;
import org.w3c.dom.nodelist;
import org.xml.sax.saxexception;

public class domtest {

  public static void main(string[] args) throws parserconfigurationexception, saxexception, ioexception {
    //创建一个documentbuilderfactory对象
    documentbuilderfactory dbf=documentbuilderfactory.newinstance();
    //创建一个doucumentbuild对象
    documentbuilder db=dbf.newdocumentbuilder();
    //解析对应的xml文件
    document doc=db.parse("tes.xml");
    //根据标签名获取node节点list
    nodelist nodelist=doc.getelementsbytagname("book");
    system.out.println("共有"+nodelist.getlength()+"本书");
    //遍历每一个book节点
    for(int i=0;i<nodelist.getlength();i++) {  
      system.out.println("第"+i+"本书");
      //获取个book节点
      //使用node类型获取book
      node book=nodelist.item(i);
      system.out.println("name: "+book.getnodename()+" value: "+book.getnodevalue()+" type: "+book.getnodetype());
      //获取node节点中的属性
      namednodemap attrs= book.getattributes();
      //遍历获取属性
      for(int j=0;j<attrs.getlength();j++) { 
      node x=attrs.item(j);
      //system.out.println(x.getnodename()+" "+x.getnodevalue()+" "+x.getnodetype());
      }
      
      //使用element对象获取节点
      element node =(element) nodelist.item(i); 
      //使用element对象下的getattribute方法可以获取指定名字的属性值
      string id=node.getattribute("id");
      system.out.println(id); 
      string type=node.getattribute("type");
      system.out.println(type);
       
      //使用node节点下的getchildnode可以获取nodelist数组,以此进行循环解析
      nodelist childnode=book.getchildnodes();
      for(int j=0;j<childnode.getlength();j++) {//getlength后会获取9个节点,因为text类型也算节点,一个<name>……</name>算一个节点,所以共有9个节点,而这些节点中,只有对象节点是我们需要的 
        node x=childnode.item(j);
        if(x.getnodetype()==node.element_node){//当节点类型为element时,获取该节点
          //获取element类型的节点名
          system.out.println("节点"+j+"的名字:"+x.getnodename()+" 值:/"+x.getlastchild().getnodevalue()+"/种类为"+x.getlastchild().getnodetype());//<name>xyz<name>,xyz属于<name>的子节点,使用getfirstchild或getlastnode效果相同
          system.out.println("节点"+j+"的名字:"+x.getnodename()+" 值:/"+x.gettextcontent()+"/种类为"+x.getnodetype());//gettextcontent方法可以获取节点中所有的text内容 将<name>xyz</name>改为<name><a>123</a>xyz</name>,会获取到xyz123
        }
      }
    }
  }
}
//为了将获取到的xml文件中内容保存下来,可以将内容保存到对象数组中一次来存储数据
<?xml version="1.0" encoding="utf-8" ?>
<bookstore>
  <book id="1" type="text">
  <name>冰与火之歌</name>
  <author>乔治马丁</author>
  <year>2014</year>
  <price>80</price>
  </book>
<book id="2">
  <name>安徒生童话</name>
  <year>2004</year>
  <price>79</price>
  <language>english</language>
</book>
</bookstore>

JAVA DOM解析XML文件过程详解

注意点

1 空白换行符也算节点,所以遍历节点时需要注意这些无用的节点会混在list中

2 text类节点返回name值都是#text,而element类节点返回value值都是null,需要注意

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。