package dataModule;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
//下面主要是org.xml.sax包的类
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.xml.sax.SAXException;
public class Xml {
String property="";
public String getProperty() {
return property;
}
public void setProperty(String property) {
this.property = property;
}
public ArrayList getXml(String path){
ArrayList al = new ArrayList();
//(1)得到DOM解析器的工厂实例
DocumentBuilderFactory domfac=DocumentBuilderFactory.newInstance();
//得到javax.xml.parsers.DocumentBuilderFactory;类的实例就是我们要的解析器工厂
try {
//(2)从DOM工厂获得DOM解析器
DocumentBuilder dombuilder=domfac.newDocumentBuilder();
//通过javax.xml.parsers.DocumentBuilderFactory实例的静态方法newDocumentBuilder()得到DOM解析器
//(3)把要解析的XML文档转化为输入流,以便DOM解析器解析它
InputStream is=new FileInputStream(path);
//(4)解析XML文档的输入流,得到一个Document
Document doc=dombuilder.parse(is);
//由XML文档的输入流得到一个org.w3c.dom.Document对象,以后的处理都是对Document对象进行的
//(5)得到XML文档的根节点
Element root=doc.getDocumentElement();
//在DOM中只有根节点是一个org.w3c.dom.Element对象。
//(6)得到节点的子节点
NodeList estate=root.getChildNodes();
if(estate!=null){
for(int i=0;i<estate.getLength();i++){
Node city=estate.item(i);
if(city.getNodeType()==Node.ELEMENT_NODE){
//(7)取得节点的属性值
String cityname=city.getAttributes().getNamedItem("cityname").getNodeValue();
//注意,节点的属性也是它的子节点。它的节点类型也是Node.ELEMENT_NODE
//(8)轮循子节点
for(Node node=city.getFirstChild();node!=null;node=node.getNextSibling()){
Xml xml =new Xml();
if(node.getNodeType()==Node.ELEMENT_NODE){
if(node.getNodeName().equals("property1")){
property=node.getFirstChild().getNodeValue();
//
}
if(node.getNodeName().equals("property2")){
property=node.getFirstChild().getNodeValue();
}
if(node.getNodeName().equals("property3")){
property=node.getFirstChild().getNodeValue();
}
if(node.getNodeName().equals("property4")){
property=node.getFirstChild().getNodeValue();
}
if(node.getNodeName().equals("property5")){
property=node.getFirstChild().getNodeValue();
}
xml.setProperty(property);
al.add(xml);
}
}
}
}//(6)这是用一个org.w3c.dom.NodeList接口来存放它所有子节点的,还有一种轮循子节点的方法,后面有介绍
}
} catch (ParserConfigurationException e) {
e.printStackTrace();
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (SAXException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return al;
}
}
xml文件
<?xml version="1.0" encoding="GB2312" standalone="no"?>
<estate>
<city cityname="chongqing">
<property1>CQ15-P000123291</property1>
<property2>CQ62-P000095732</property2>
<property3>CQ41-P000101178</property3>
<property4>CQ58-P000077181</property4>
</city>
</estate>
调用
Xml xml = new Xml();
ArrayList al = xml.getXml(path);
int alRows = al.size();
for(int i=0;i<alRows;i++){
Xml xml1 = (Xml)al.get(i);
.........
}
分享到:
相关推荐
用java读取xml文件的四种方法
文档中有代码案例,详细讲解了使用java读取xml,并附带有关于xml的dtd讲解,里面包含详细的文档和代码案例。和读取xml所需的jar。
使用Java读取XML配置文件
java读取xml文件 ,程序自带jar包在mylib下,加入工程即可,工程导入可用,更具自己需要读取xml文件生成所需文件。
简单利用java读取xml中的标签,也是写xml
NULL 博文链接:https://itjiehun.iteye.com/blog/670197
java_xml_api,java操作XML文档
java实现读取xml文件内容
java读取XML文件内容的四种方法[归类].pdf
SAX.java 操作xml文件SAX.java 操作xml文件SAX.java 操作xml文件SAX.java 操作xml文件SAX.java 操作xml文件SAX.java 操作xml文件SAX.java 操作xml文件SAX.java 操作xml文件
java xml.java操作XML文档,简单易用,快速生成
java从xml中读入数据并存入到sqlserver2005数据库中
java代码读取xml文件,生成树形图。这里是源码,可直接使用,是我项目中提取生成树的核心文件。
java实现的一个读取本地xml文件的例子,进入正题: 需要的包jdom2-2.0.6.jar:下载地址,http://mvnrepository.com/artifact/org.jdom/jdom2 此例子比较简单
java读取xml的四种方法,欢迎下载java读取xml的四种方法
Java读取xml文件中oracle数据库连接,JAVA与ORACLE连接的代码.
java读取xml文件的四种方法: 第一种 DOM 实现方法 第二种 DOM4J实现方法 第三种 JDOM实现方法 第四种SAX实现方法