- 浏览: 287274 次
- 性别:
- 来自: 福建龙岩
文章分类
- 全部博客 (201)
- JavaSE (20)
- Struts1 (7)
- Struts2 (0)
- Hibernate (0)
- Spring (2)
- Flex (0)
- Ajax (1)
- web (20)
- Database (17)
- jsp/servlet (1)
- javascirpt (14)
- freemarker (2)
- jquery (6)
- SEO优化 (26)
- JSP&Servlet (1)
- PHP (32)
- CSS (12)
- Magento (9)
- 网站性能优化 (3)
- Flash (1)
- 生活 (3)
- 网站建设 (15)
- ZenCart (12)
- web自动化 (1)
- 企业应用 (1)
- LINUX (4)
- 字符集 (2)
- Delphi (1)
- C# (4)
- 移动互联网 (1)
- Vim (1)
最新评论
-
谷超:
第一次搞freemarker,test.ftl这个文件应该放在 ...
freemarker入门例子 -
zyhui98:
file_get_contents用不了
通过IP获取地理位置 -
ljx0517:
那ff下无法获取 路径怎么办呢
common-fileupload中FileItemStream的getName()方法 -
kaixuan_166:
多谢,刚好用到
通过Google获取天气预报信息 -
lufengdie:
借用下,嘿嘿··
java查询IP物理地址
import java.io.File;
import java.io.FileWriter;
import java.util.Iterator;
import org.dom4j.Document;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
public class DOM4JTest {
/** *//** */
/** *//** */
/** *//** */
/** *//**
* DOM4J读写XML示例
*
* @param args
* @throws Exception
*/
public static void main(String[] args) {
try {
XMLWriter writer = null;// 声明写XML的对象
SAXReader reader = new SAXReader();
OutputFormat format = OutputFormat.createPrettyPrint();
format.setEncoding("GBK");// 设置XML文件的编码格式
String filePath = "d:\\student.xml";
File file = new File(filePath);
if (file.exists()) {
Document document = reader.read(file);// 读取XML文件
Element root = document.getRootElement();// 得到根节点
boolean bl = false;
for (Iterator i = root.elementIterator("学生"); i.hasNext();) {
Element student = (Element) i.next();
if (student.attributeValue("sid").equals("001")) {
// 修改学生sid=001的学生信息
student.selectSingleNode("姓名").setText("王五");
student.selectSingleNode("年龄").setText("25");
writer = new XMLWriter(new FileWriter(filePath), format);
writer.write(document);
writer.close();
bl = true;
break;
}
}
if (bl) {
// 添加一个学生信息
Element student = root.addElement("学生");
student.addAttribute("sid", "100");
Element sid = student.addElement("编号");
sid.setText("100");
Element name = student.addElement("姓名");
name.setText("嘎嘎");
Element sex = student.addElement("性别");
sex.setText("男");
Element age = student.addElement("年龄");
age.setText("21");
writer = new XMLWriter(new FileWriter(filePath), format);
writer.write(document);
writer.close();
}
} else {
// 新建student.xml文件并新增内容
Document _document = DocumentHelper.createDocument();
Element _root = _document.addElement("学生信息");
Element _student = _root.addElement("学生");
_student.addAttribute("sid", "001");
Element _id = _student.addElement("编号");
_id.setText("001");
Element _name = _student.addElement("姓名");
_name.setText("灰机");
Element _age = _student.addElement("年龄");
_age.setText("18");
writer = new XMLWriter(new FileWriter(file), format);
writer.write(_document);
writer.close();
}
System.out.println("操作结束! ");
} catch (Exception e) {
e.printStackTrace();
}
}
}
执行结果应该是这样:
循环解析节点:
try {
Document authtmp = DocumentHelper.parseText(xml);
List<Element> list = authtmp.selectNodes("//sms/node");
for (int j = 0; j < list.size(); j++) {
Element node = (Element) list.get(j);
nodeByNodes(node);
}
} catch (Exception e) {
e.printStackTrace();
}
}
private void nodeByNodes(Element node) {
if (node.element("node") != null) {
String id = node.attributeValue("id");
String name = node.attributeValue("name");
System.out.print(id + "-------");
System.out.println(name);
for (Iterator i = node.elementIterator("node"); i.hasNext();) {
Element newNode = (Element) i.next();
nodeByNodes(newNode);
}
} else {
String id = node.attributeValue("id");
String name = node.attributeValue("name");
System.out.print(id + "-------");
System.out.println(name);
}
}
其次DOM4J的解释
一.Document对象相关
1.读取XML文件,获得document对象.
Document document = reader.read(new File("input.xml"));
2.解析XML形式的文本,得到document对象.
Document document = DocumentHelper.parseText(text);
3.主动创建document对象.
Element root = document.addElement("members");// 创建根节点
二.节点相关
1.获取文档的根节点.
2.取得某节点的单个子节点.
3.取得节点的文字
也可以用:
这个是取得根节点下的name字节点的文字.
4.取得某节点下名为"member"的所有字节点并进行遍历.
for (Iterator it = nodes.iterator(); it.hasNext();) {
Element elm = (Element) it.next();
// do something
}
5.对某节点下的所有子节点进行遍历.
Element element = (Element) it.next();
// do something
}
6.在某节点下添加子节点.
7.设置节点文字.
8.删除某节点.
9.添加一个CDATA节点.
contentElm.addCDATA(diary.getContent());
contentElm.getText(); // 特别说明:获取节点的CDATA值与获取节点的值是一个方法
contentElm.clearContent(); //清除节点中的内容,CDATA亦可
三.属性相关.
1.取得某节点下的某属性
Attribute attribute=root.attribute("size");// 属性名name
2.取得属性的文字
也可以用:
这个是取得根节点下name字节点的属性firstname的值.
3.遍历某节点的所有属性
for(Iterator it=root.attributeIterator();it.hasNext();){
Attribute attribute = (Attribute) it.next();
String text=attribute.getText();
System.out.println(text);
}
4.设置某节点的属性和文字.
5.设置属性的文字
attribute.setText("sitinspring");
6.删除某属性
root.remove(attribute);
四.将文档写入XML文件.
1.文档中全为英文,不设置编码,直接写入的形式.
writer.write(document);
writer.close();
2.文档中含有中文,设置编码格式写入的形式.
format.setEncoding("GBK"); // 指定XML编码
XMLWriter writer = new XMLWriter(new FileWriter("output.xml"<
发表评论
-
几款开源web自动化测试工具
2011-08-03 02:24 16591 测试 WEBSELENIUM可以 ... -
Jave获得泛型类型(转)
2011-03-28 16:35 869原文http://www.iteye.com/topic/58 ... -
SiteMesh使用入门
2011-01-20 12:43 845sitemesh应用Decorator模式,用filte ... -
HTTPClient详解
2010-11-15 16:06 3109HttpClient是实现了HTTP1.0和1.1标准的jav ... -
Java制作自动访问网站机器人!(转)
2010-10-25 16:02 1343如何制作一些论坛的自动发言机器人?(如果没有图片验证码的话!) ... -
通过Google获取天气预报信息
2010-08-12 14:38 2088要获得天气预报信息可用利用Google提供的借口, ht ... -
Java获取操作系统以及浏览器信息
2010-08-11 17:52 1969Properties props=System.getProp ... -
java操作时间日期类
2010-07-29 18:18 716有时候,我们需要把一个特定的字符串转成日期类型,有时候又要把日 ... -
用java把中文转拼音
2010-07-14 10:30 1517实现用java将中文字转成相应的拼音,能实现大多数的汉字。源码 ... -
java操作cookie
2010-07-01 15:27 751import javax.servlet.http.Cooki ... -
理解ThreadLocal
2010-06-29 14:42 606早在JDK 1.2的版本中就提 ... -
java查询IP物理地址
2010-06-23 18:46 1657根据访问的IP得到具体的IP物理地址,在这里要采用HttpUR ... -
java邮箱验证正则表达式
2010-06-11 15:11 2570"^([a-z0-9A-Z]+[-|\\.]?)+[ ... -
字符集系列之----字符集和编码
2010-06-10 10:36 716很久很久以前,有一群 ... -
字符集系列之-----字符集、编码概念
2010-06-10 10:35 742要谈编码就要先谈两个十分容易混淆的概念,一个是编码字符集 (C ... -
字符集系列之----深入字符集和编码
2010-06-10 10:34 462一、什么是字符集?什么是编码? 字符(Character)是文 ... -
每隔一段时间生成随机数
2010-05-07 16:48 1614import java.util.Random; im ... -
common-fileupload中FileItemStream的getName()方法
2010-04-06 17:16 4429在使用common-fileupload的Fil ... -
IO流复习(列出指定目录下的指定格式文件)
2010-02-25 15:50 1000import java.io.*; import java. ...
相关推荐
NULL 博文链接:https://sxpujs.iteye.com/blog/375485
Dom4j 读写 XML
java中dom4j读写XML(项目中含所需要的jar包)
基于dom4j的读写xml文件的工具包。封装了dom4j操作xml文档的常和方法。 支持两种读写方法。1:针对小文件的读取整个文档,2:针对大文件的,逐行读取。读到几百M文件毫无压力。
Dom4j解析教程。详细讲解如何使用dom4j解析xml,简单易懂。
简单的读取xml,利用dom4j读写xml实例xmldemo
完整的讲解一个dom4j对xml的增删改查
dom4j是非常优秀的xml解析包,操作起来读写xml非常方便。把自己写的一个读写dom4j.xml实例共享给大家
使用dom4j对xml的读写(这个感觉比jdom功能好点,但是复杂一点点)
使用dom4j读写XML文档 1.获取文档的根节点. Element rootElm = document.getRootElement(); 2.取得某节点的单个子节点. Element memberElm=root.element("member");// "member"是节点名 3.取得节点的文字 String ...
使用DOM4J对XML文件操作-添加、修改、删除、获取元素节点
总结DOM、SAX、JDOM、DOM4J读写xml文档的多种方法。
例题采用的是dom4j对xml的操作,包含了对xml的增加删除修改操作.
使用dom4j对xml文档进行增删改. 查询就不用说了,使用elements(....)/element(...)/attributeValue()/getText()等方法
java操作xml源码 操作方式包括:dom和dom4j dom是W3C规范,比较典型的JAVA操作XML方式,适用于小型文件。 dom4j是开源的性能以及效率最好的,也是一个典型例子。...采用dom4j写xml 以及dom4j方式读XML
1、xml文档解析 2、 dom4j解析xml 3、实现xml文件解析 xml字符串解析 xml MAP键值对解析 4、实现xml写入与生成文件
dom4j解析xml文件的压缩包,完整版。对jdom进行了封装。包含源码,jar包以及所需的全部内容。
Java用dom4j对xml进行增删改查操作,提供这个资料给大家参考。