xml解析
2015-06-15 00:27
197 查看
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.
准备工作:
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.
相关文章推荐
- XML解析之XStream解析
- 909422229_DOM4J读取XML文件与解析StringXML
- AndroidManifest.xml文件解析
- 【Android】实现XML解析的几种技术
- xml的几种解析方式
- XML字符串解析成对象的时候应注意空格
- 解析xml文件时,错误信息org.xml.sax.SAXParseException:Parser has reached the entity expansion limit "64,000" set by the Application.的解决办法
- libxml库解析XML文件
- Pull解析XML,上拉刷新下拉加载
- 【转载】web.xml加载顺序与web.xml常用节点解析
- iPhone SDK 解析 xml的官方示例代码
- java xml 解析
- Android解析编译之后的所有文件(so,dex,xml,arsc)格式
- Android之XML文件解析
- Android解析xml文件
- JAXB解析xml实例
- JS解析XML文件和XML字符串
- android 解析XML
- xml解析之Dom
- 使用JDOM解析xml文件