java中调用xml的方法:DocumentBuilderFactory
首先得到:得到 DOM 解析器的工厂实例 DocumentBuilderFactory domfac=DocumentBuilderFactory.newInstance();
然后从 DOM 工厂获得 DOM 解析器
DocumentBuilder dombuilder=domfac.newDocumentBuilder();
3 )把要解析的 XML 文档转化为输入流,以便 DOM 解析器解析它
InputStream is= new FileInputStream("test1.xml");
( 4 )解析 XML 文档的输入流,得到一个 Document
Document doc=dombuilder.parse(is);
( 5 )得到 XML 文档的根节点
Element root=doc.getDocumentElement();
( 6 )得到节点的子节点
NodeList books=root.getChildNodes();
- package com.st.demo;
- import java.io.File;
- import java.io.FileInputStream;
- import java.io.InputStream;
- 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 XmlReader {
- public static void main(String[] args) {
- XmlReader reader = new XmlReader();
- }
- public XmlReader(){
- DocumentBuilderFactory domfac = DocumentBuilderFactory.newInstance();
- try {
- DocumentBuilder domBuilder = domfac.newDocumentBuilder();
- InputStream is = new FileInputStream(new File("D:/test1.xml"));
- Document doc = domBuilder.parse(is);
- Element root = doc.getDocumentElement();
- NodeList books = root.getChildNodes();
- if(books!=null){
- for (int i = 0; i < books.getLength(); i++) {
- Node book = books.item(i);
- if(book.getNodeType()==Node.ELEMENT_NODE) {
- //(7)取得节点的属性值
- String email=book.getAttributes().getNamedItem("email").getNodeValue();
- System.out.println(email);
- //注意,节点的属性也是它的子节点。它的节点类型也是Node.ELEMENT_NODE
- //(8)轮循子节点
- for(Node node=book.getFirstChild();node!=null;node=node.getNextSibling()) {
- if(node.getNodeType()==Node.ELEMENT_NODE) {
- if(node.getNodeName().equals("name")) {
- String name=node.getNodeValue();
- String name1=node.getFirstChild().getNodeValue();
- System.out.println(name);
- System.out.println(name1);
- }
- if(node.getNodeName().equals("price")) {
- String price=node.getFirstChild().getNodeValue();
- System.out.println(price);
- }
- }
- }
- }
- }
- }
- } catch (Exception e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- }
- }
- <?xml version="1.0" encoding="GB2312" standalone="no"?>
- <books>
- <book email="zhoujunhui">
- <name>rjzjh</name>
- <price>jjjjjj</price>
- </book>
- </books>
java解析XML的三种方法
1.SAX事件解析
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
package com.wzh.sax;
import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;
//
public class Saxhandler extends DefaultHandler {
@Override
public void startDocument() throws SAXException {
System.out.println( "开始解析XML文档..." );
}
@Override
public void endDocument() throws SAXException {
System.out.println( "结束解析XML文档..." );
}
@Override
public void startElement(String uri, String localName, String qName,
Attributes attributes) throws SAXException {
// TODO Auto-generated method stub
super .startElement(uri, localName, qName, attributes);
System.out.println( "开始解析节点[" +qName+ "]..." );
System.out.println( "共有[" +attributes.getLength()+ "]个属性" );
}
@Override
public void characters( char [] ch, int start, int length)
throws SAXException {
// TODO Auto-generated method stub
super .characters(ch, start, length);
String content = new String(ch,start,length);
System.out.println(content);
}
@Override
public void endElement(String uri, String localName, String qName)
throws SAXException {
// TODO Auto-generated method stub
super .endElement(uri, localName, qName);
System.out.println( "结束解析XML节点..." );
}
}
|
2.Dom加载解析
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
package com.wzh.dom;
import java.util.Iterator;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
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;
public class DomHandler {
/*
* 解析XML
*/
public void read(String fileName) throws Exception {
// 定义工厂API 使应用程序能够从XML文档获取生成DOM对象树的解析器
DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
// 获取此类的实例之后,将可以从各种输入源解析XML
DocumentBuilder builder = factory.newDocumentBuilder();
// builder.parse(this.getClass().getResourceAsStream("/" + fileName));
// Document接口表示整个HTML或XML文档,从概念上讲,它是文档树的根,并提供对文档数据的基本访问
Document document = builder.parse( this .getClass().getResourceAsStream(
"/" + fileName));
// 获取根节点
Element root = document.getDocumentElement();
System.out.println(root.getNodeName());
//读取database节点NodeList接口提供对节点的有序集合的抽象
NodeList nodeList = root.getElementsByTagName( "database" );
for ( int i = 0 ; i < nodeList.getLength(); i++) {
// 获取一个节点
Node node = nodeList.item(i);
// 获取该节点所有属性
NamedNodeMap attributes = node.getAttributes();
for ( int j = 0 ; j < attributes.getLength(); j++) {
Node attribute = attributes.item(j);
System.out.println(attribute.getNodeName() + ":"
+ attribute.getNodeValue());
}
//获取所有子节点数据
NodeList childNodes=node.getChildNodes();
for ( int j = 0 ; j < childNodes.getLength(); j++) {
Node childNode=childNodes.item(j);
System.out.println(childNode.getNodeName()+ ":" +childNode.getNodeValue());
}
}
}
public static void main(String[] args) throws Exception {
new DomHandler().read( "data-source.xml" );
}
}
|
3.dom4j解析
package com.wzh.dom4j;
import java.io.FileOutputStream;
import java.sql.DatabaseMetaData;
import java.util.Iterator;
import java.util.List;
import org.dom4j.*;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
public class Dom4jHandler {
public void add() throws Exception {
// 1.创建一个Document
Document document = DocumentHelper.createDocument();
// 2.给Document添加数据
Element root = document.addElement("DataSource");
// 添加注释
root.addComment("这是注释信息");
// 在root根节点下面添加一个子节点
Element database = root.addElement("database");
database.addAttribute("name", "mysql");
database.addAttribute("version", "5.0");
// 添加子节点
database.addElement("driver").setText("com.mysql.jdbc.Driver");
database.addElement("url")
.setText("jdbc:mysql://localhost:3306/myjdbc");
database.addElement("user").setText("root");
database.addElement("password").setText("root");
// 3.将Document写出文件
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("utf-8");
// FileOutputStream默认生成的路径在根路径
XMLWriter xw = new XMLWriter(new FileOutputStream("db.xml"), format);
xw.write(document);
xw.close();
}
public void update(String fileName) throws Exception {
// sax解析器
SAXReader saxReader = new SAXReader();
// 读到对象
Document document = saxReader.read(this.getClass().getResourceAsStream(
"/" + fileName));
Element root = document.getRootElement();
List<Element> databases_node = root.elements("database");
for (Element database_node : databases_node) {
if (database_node.attributeValue("name").equalsIgnoreCase("mysql")) {
System.out.println("old:"
+ database_node.attributeValue("name"));
database_node.attribute("name").setText("Oracle");
System.out.println("update:"
+ database_node.attributeValue("name"));
database_node.element("driver").setText("oracel");
database_node.element("url").setText("jdbc");
// 删除password节点
database_node.remove(database_node.element("password"));
// 删除属性
database_node.remove(database_node.attribute("version"));
}
}
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("utf-8");
// FileOutputStream默认生成的路径在根路径
XMLWriter xw = new XMLWriter(new FileOutputStream("db2.xml"), format);
xw.write(document);
xw.close();
}
public void read(String fileName) throws Exception {
// sax解析器
SAXReader saxReader = new SAXReader();
// 读到对象
Document document = saxReader.read(this.getClass().getResourceAsStream(
"/" + fileName));
Element root = document.getRootElement();
System.out.println("根节点:" + root.getName());
// List<Element> childElements=root.elements();
List<Element> childElements = root.elements("database");
for (Element child : childElements) {
// 获取属性 不知道属性名称时的遍历方法
List<Attribute> attributes = child.attributes();
// for (Attribute attribute : attributes) {
// System.out.println(attribute.getName()+":"+attribute.getValue());
// }
String name = child.attributeValue("name");
// String version = child.attributeValue("version");
String version = child.attribute("version").getValue();
System.out.println(name + ":" + version);
// //获取子节点
// List<Element> childs=child.elements();
// for (Element element : childs) {
// System.out.println(element.getName()+":"+element.getText());
// }
System.out.println(child.elementText("driver"));
System.out.println(child.element("url").getText());
System.out.println(child.elementTextTrim("user"));
System.out.println(child.element("password").getTextTrim());
}
}
public static void main(String[] args) throws Exception {
// new Dom4jHandler().read("data-source.xml");
// new Dom4jHandler().add();
new Dom4jHandler().update("data-source.xml");
}
}
转载于:https://www.cnblogs.com/jiangyi666/p/5677785.html
java中调用xml的方法:DocumentBuilderFactory相关推荐
- 【Unity3D】Android Studio 工程中使用 Java 代码调用 Unity 的 C# 脚本 ( Java 中调用 UnityPlayer#UnitySendMessage 方法 )
文章目录 一. Java 调用 C# 依赖库准备 1.依赖库位置 2.unityLibrary 依赖库位置 二. Java 调用 C# 的 UnityPlayer#UnitySendMessage 方 ...
- java中调用dll文件的两种方法
https://www.cnblogs.com/huozhong/p/5830485.html JNA地址:http://blog.csdn.net/shendl/article/details/35 ...
- 如何在java中调用js方法
[java] view plain copy/* * 加载脚本引擎,并在java中调用js方法 */ public void test2() { ScriptEngineManager manager ...
- java中调用 dll 动态库的简洁方法 JNative
Java中调用DLL方法,是通过JNI接口实现的,http://www.ibm.com/developerworks/cn/java/l-linux-jni/ 这里有详细的说明.大概是先用Java写一 ...
- java中调用js_java编程中实现调用js方法分析
本文实例讲述了java编程中实现调用js方法.分享给大家供大家参考,具体如下: /* * 加载脚本引擎,并在java中调用js方法 */ public void test2() { ScriptEng ...
- Java 中的 XML:Java 文档模型的用法
Java 中的 XML:Java 文档模型的用法 英文原文 内容: 代码对比 DOM JDOM dom4j Electric XML XPP 结束语 下一次... 参考资料 关于作者 对本文的评价 相 ...
- java中调用python
在Java中调用Python </h1><div class="clear"></div><div class="postBod ...
- 如何从Java中打印XML?
本文翻译自:How to pretty print XML from Java? I have a Java String that contains XML, with no line feeds ...
- 宣布EAXY:使Java中的XML更容易
Java中的XML库是一个雷区. 操作和读取XML所需的代码量令人震惊,使用不同的库遇到类路径问题的风险很大,并且对名称空间的处理带来许多混乱和错误. 最糟糕的是,情况似乎并没有改善. 一位同事让我意 ...
- 宣布EAXY:在Java中简化XML
Java中的XML库是一个雷区. 操作和读取XML所需的代码量令人震惊,使用不同的库遇到类路径问题的风险很大,并且命名空间的处理带来了很多混乱和错误. 最糟糕的是,情况似乎并没有改善. 一位同事让我意 ...
最新文章
- 最常用的20个Git命令与示例,你都会了么?
- 网站优化离不开内容更新
- 【JAVA资料免费下载】158个JAVA免豆精品资料汇总——下载目录(转载)
- 逆向基础之C语言 第一篇
- 用备份进行Active Directory的灾难重建:Active Directory系列之三
- linux out 日志,关于Linux中nohup.out日志过大问题(示例代码)
- oracle10g的rat模拟,Oracle 10g Logminer 研究及测试
- linux命令:watch 、lsmod、mdadm 创建软RAID
- Flash Player版本相关问题
- Angular CLI 生成项目时css less scss样式使用说明
- JAVA中整型常量的长度_以下的 能正确表示Java语言中的一个整型常量。_学小易找答案...
- sas 服务器版安装文件,SAS软件各个版本,包括服务器版本的切磋了解
- uploadify php使用,如何在ThinkPHP中使用Uploadify对图片进行上传
- do sb suggest to_suggest_suggest to do 和 suggest doing 的区别
- Ethernet和802.3的区别
- SpringSecurity实战(五)-认证流程源码分析
- Chapter Two:无限debugger的原理与绕过与断点调试
- 怎么删除拨号连接,取消掉宽带拨号?
- pure-ftp 启用虚拟账户的问题
- Vue项目中实现改变屏幕尺寸重新刷新页面-计算页面尺寸