`
小猪猪08
  • 浏览: 5581 次
  • 性别: Icon_minigender_2
  • 来自: 深圳
社区版块
存档分类
最新评论

xml解析

xml 
阅读更多
1、DOM解析的步奏
准备工作:
   1.创建DocumentBuilderFactory的对象
   2.创建DocumentBuilder对象
   3.通过DocumentBuilder对象的parse(String fileName)方法解析xml文件
   4.通过Document的getElementsByTagName("")获取解析的属性
   5.遍历循环出有多少个属性和属性值(NodeList 的getLength()获得长度)
例如:
// 创建DocumentBuilderFactory对象
DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();
//创建DocumentBuilder对象
try {
DocumentBuilder db=dbf.newDocumentBuilder();
//DocumentBuilder对象的parse来解析xml文件
Document document=db.parse("books.xml");
//获取属性集合
NodeList nodelist=document.getElementsByTagName("book");
for(int i=0;i<nodelist.getLength();i++){
//通过item(index)来获取节点
Node node=nodelist.item(i);
NamedNodeMap map=node.getAttributes();
for(int j=0;j<map.getLength();j++){
System.out.println("第"+ (i+1) +"本书的第"+(j+1)+"个属性名为"+map.item(j).getNodeName());
System.out.println("第"+ (i+1) +"本书的第"+(j+1)+"个属性值为"+map.item(j).getNodeValue());
}
                      //获取子节点集合
                     NodeList books=node.getChildNodes();
                    //遍历子节点的属性和值
                    for(int k = 0;k < books.getLength();k ++;){
                       if(books.item(k).getNodeType()==Node.ElEMENT_NODE){
                          System.out.print("第"+(k+1)+"个子节点的节点名为:"+books.item(k).getNodeName());
                          System.out.println("--值为"+books.item(k).getTextContent());
                       }
                    
                    }
}
} catch (Exception e) {
e.printStackTrace();
}

2.
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics