java解析xml实例
来源:互联网 发布:淘宝网招聘信息 编辑:程序博客网 时间:2024/05/02 04:38
import java.io.FileInputStream;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
public class DomParse {
/**
* 构造器方法
*
*/
public DomParse() {
// TODO Auto-generated constructor stub
try
{
// 得到DOM解析器的工厂实例
DocumentBuilderFactory docfcty = DocumentBuilderFactory.newInstance();
// 从DOM工厂获得解析器
DocumentBuilder dombuilder=docfcty.newDocumentBuilder();
// 将文件转换为输入流
InputStream in = new FileInputStream("book.xml");
Document doc=dombuilder.parse(in);
// 得到根元素
Element root=doc.getDocumentElement();
// 获得所有子节点
NodeList books=root.getChildNodes();
if(books != null)
{
System.out.println("books.length===========" + books.getLength());
List nodeList = new ArrayList();
// 循环节点
for(int i = 0; i < books.getLength(); i++)
{
Node book = books.item(i);
if(book.getNodeType() == Node.ELEMENT_NODE) // ELEMENT_NODE是节点类型
{
// 获得节点属性值
String email = book.getAttributes().getNamedItem("email").getNodeValue();
System.out.println("email=========" + email);
// 循环子节点
for(Node node = book.getFirstChild(); node != null; node = node.getNextSibling())
{
if(node.getNodeType() == Node.ELEMENT_NODE)
{
String name = "";
String price = "";
// 取得name节点的值
if(node.getNodeName().equals("name"))
{
name = node.getFirstChild().getNodeValue();
System.out.println("name=============" + name);
}
// 取得price节点的值
if(node.getNodeName().equals("price"))
{
price = node.getFirstChild().getNodeValue();
System.out.println("price==========" + price);
}
// 将取得子节点放入数组(作为一条记录存储)
String []strArr = {name, price};
// 将数组放入集合
nodeList.add(strArr);
}
}
System.out.println("nodelist.size=========" + nodeList.size());
}
}
}
}
catch(Exception e)
{
e.printStackTrace();
}
}
book.xml:
<?xml version="1.0" encoding="gb2312"?>
<books>
<book email="lxc0904@sina.com">
<name>Java Thingking</name>
<price>100</price>
</book>
</books>
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
new DomParse();
}
}
- java解析xml实例
- JAVA解析Xml实例
- java解析XML实例
- java解析XML文件实例
- java dom4j解析xml实例
- java xml解析实例浅谈
- JAVA解析XML简单实例
- Java XMl解析DOM4j实例
- 创建并解析XML文件Java实例
- JAVA的XML编程实例解析
- 新手入门:Java XML编程实例解析
- 使用java解析xml的实例程序
- Java操作XML编程实例解析
- JAVA DOM生成和解析XML实例
- Java---DOM解析XML文档详解实例
- Java对XML文档进行解析---实例
- XML实例解析1
- 解析xml文件实例
- 公司开始用Agile
- 突出显示当前选中的行(代码片段)
- 如何操作Excel
- 修改 DBNavigator 的 click事件;
- Perl 连接Postgresql
- java解析xml实例
- ASCII 字元表
- Gnome 美化
- int和Integer的区别
- WPF快速入手实例篇 --- Binding使用
- 菜鸟喝咖啡(前提)--浅谈java中的类和对象
- CSDN博客
- 在Ubuntu上安装beryl实现3D桌面(转)
- 单例模式