Dom4J读写xml
解析读取XML
public static void main(String[] args) {
//1获取SaxReader对象
SAXReader reader=new SAXReader();
try {
//2使用Saxrreader对象加载xml文件,返回Document对象
Document document=reader.read(new File("student.xml"));
//3使用document对象或根元素
Element rootele=document.getRootElement();
//4获取子元素的集合(获取的是student子元素的集合)
List<Element> lsstu_ele=rootele.elements("student");
System.out.println("student元素的个数:"+lsstu_ele.size());
//遍历student元素
for (Element stuele : lsstu_ele) {
/***********************************
//获取student元素下的子元素
Element sid_ele=stuele.element("sid");
Element sname_ele=stuele.element("sname");
Element sex_ele=stuele.element("sex");
Element address_ele=stuele.element("address");
Element age_ele=stuele.element("age");
//获取每个子元素的文本内容
System.out.println("编号:"+sid_ele.getText());
System.out.println("姓名:"+sname_ele.getText());
System.out.println("性别:"+sex_ele.getText());
System.out.println("地址:"+address_ele.getText());
System.out.println("年龄:"+age_ele.getText());
System.out.println("========================");
**************************************/
//获取每个子元素的文本内容
System.out.println("编号:"+stuele.elementText("sid"));
System.out.println("姓名:"+stuele.elementText("sname"));
System.out.println("性别:"+stuele.elementText("sex"));
System.out.println("地址:"+stuele.elementText("address"));
System.out.println("年龄:"+stuele.elementText("age"));
System.out.println("========================");
}
} catch (DocumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
向xml文件中添加节点并写入文件保存;
public static void main(String[] args) {
//1创建SaxReader对象
SAXReader reader=new SAXReader();
try {
//2读取xml文档,并返回document对象
Document document=reader.read(new File("student.xml"));
//3获取根元素
Element rootele=document.getRootElement();
//4在根元素下添加student子元素
Element st_ele=rootele.addElement("student");
//在新增的student元素下添加其他子元素
Element sid_ele=st_ele.addElement("sid");
Element sname_ele=st_ele.addElement("sname");
Element sex_ele=st_ele.addElement("sex");
Element address_ele=st_ele.addElement("address");
Element age_ele=st_ele.addElement("age");
//在每个子元素下添加内容
Scanner sc=new Scanner(System.in);
System.out.println("输入编号:");
sid_ele.setText(sc.next());
System.out.println("输入姓名:");
sname_ele.setText(sc.next());
System.out.println("输入性别:");
sex_ele.setText(sc.next());
System.out.println("输入地址:");
address_ele.setText(sc.next());
System.out.println("输入年龄:");
age_ele.setText(sc.next());
//创建字节输出流对象
FileOutputStream fout=new FileOutputStream("student.xml");
//创建缓冲区字符输出流对象
BufferedWriter bw=new BufferedWriter(new OutputStreamWriter(fout, "utf-8"));
//写文档到xml文件
document.write(bw);
bw.flush();
bw.close();
System.out.println("增加成功!");
} catch (DocumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
修改xml 文件中的节点并写入文件保存;
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
//1创建SaxReader对象
SAXReader reader=new SAXReader();
try {
//2读取xml文档,并返回document对象
Document document=reader.read(new File("student.xml"));
//3获取根元素
Element rootele=document.getRootElement();
//4获取student子元素的集合
List<Element> lsst_ele=rootele.elements("student");
System.out.println("请输入要修改的学生编号:");
String sid=sc.next();
for (Element stu_ele : lsst_ele) {
if(stu_ele.elementText("sid").equals(sid)){
System.out.println("输入姓名:");
stu_ele.element("sname").setText(sc.next());
System.out.println("输入性别:");
stu_ele.element("sex").setText(sc.next());
System.out.println("输入地址:");
stu_ele.element("address").setText(sc.next());
System.out.println("输入年龄:");
stu_ele.element("age").setText(sc.next());
break;
}
}
//创建字节输出流对象
FileOutputStream fout=new FileOutputStream("student.xml");
//创建缓冲区字符输出流对象
BufferedWriter bw=new BufferedWriter(new OutputStreamWriter(fout, "utf-8"));
//写文档到xml文件
document.write(bw);
bw.flush();
bw.close();
System.out.println("修改成功!");
} catch (DocumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
删除xml文件中的节点
public static void main(String[] args) {
Scanner sc=new Scanner(System.in);
//1创建SaxReader对象
SAXReader reader=new SAXReader();
try {
//2读取xml文档,并返回document对象
Document document=reader.read(new File("student.xml"));
//3获取根元素
Element rootele=document.getRootElement();
//获取要移除的学生编号
System.out.println("请输入要删除的学生编号:");
String sid=sc.next();
//获取student元素的集合
List<Element> lsstu_ele=rootele.elements("student");
for (Element stu_ele : lsstu_ele) {
//在元素中查找学生编号内容是否与输入的一致
if(stu_ele.elementText("sid").equals(sid)){
rootele.remove(stu_ele);//删除整个student元素
System.out.println("元素删除成功!");
break;
}
}
//创建字节输出流对象
FileOutputStream fout=new FileOutputStream("student.xml");
//创建缓冲区字符输出流对象
BufferedWriter bw=new BufferedWriter(new OutputStreamWriter(fout, "utf-8"));
//写文档到xml文件
document.write(bw);
bw.flush();
bw.close();
System.out.println("移除成功!");
} catch (DocumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
xml读写的工具类方法示例
/**
* 将Document对象写入到xml文件
* @throws IOException
* */
public static void XmlToFile(Document doc) throws IOException{ //创建字节输出流对象
FileOutputStream fout=new FileOutputStream(new File("student.xml"));
//创建字节流缓冲区,加快写出速度
BufferedOutputStream bout=new BufferedOutputStream(fout); //创建字符输出流对象
BufferedWriter bw=new BufferedWriter(new OutputStreamWriter(bout, "utf-8")); doc.write(bw); bw.flush();
bw.close();
System.out.println("写xml文件成功");
}
/**
* 从xml文件中获取学生的对象集合
* */
public static List<Student> fileToList(){
SAXReader reader=new SAXReader();
List<Student> lsst=new ArrayList<Student>(); try {
Document doc=reader.read(new File("student.xml")); //获取根元素
Element root_ele=doc.getRootElement(); //从xml文件获取student子元素集合
List<Element> lsst_ele=root_ele.elements("student");
if(lsst_ele!=null&&!lsst_ele.isEmpty()){//有student子元素存在
for (Element stu_ele : lsst_ele) {
Student st=new Student();
st.setSid(stu_ele.elementText("sid"));
st.setSname(stu_ele.elementText("sname"));
st.setSex(stu_ele.elementText("sex"));
st.setAddress(stu_ele.elementText("address"));
st.setAge(Integer.parseInt(stu_ele.elementText("age"))); lsst.add(st);//将学生对象加入到集合中
}
}
} catch (NumberFormatException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (DocumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return lsst;
}
Dom4J读写xml的更多相关文章
- Dom4j下载及使用Dom4j读写XML简介
sitinspring(如坐春风)原创,转载请注明作者及出处. 要使用dom4j读写XML文档,需要先下载dom4j包,dom4j官方网站在 http://www.dom4j.org/目前最新dom4 ...
- Dom4j下载及使用Dom4j读写XML简介(转)
Dom4j下载及使用Dom4j读写XML简介 要使用dom4j读写XML文档,需要先下载dom4j包,dom4j官方网站在 http://www.dom4j.org/目前最新dom4j包下载地址:ht ...
- dom4j读写XML文档
dom4j 最常用最简单的用法(转) 要使用dom4j读写XML文档,需要先下载dom4j包,dom4j官方网站在 http://www.dom4j.org/目前最新dom4j包下载地址:http:/ ...
- dom4j读写XML文件
XML文件格式: <?xml version="1.0" encoding="UTF-8"?> <company> <employ ...
- 【网络爬虫】【java】微博爬虫(四):数据处理——jsoup工具解析html、dom4j读写xml
之前提到过,对于简单的网页结构解析,可以直接通过观察法.手工写正则解析,可以做出来,比如网易微博.但是对于结构稍微复杂点的,比如新浪微博,如果还用正则,用眼睛一个个去找,未免太麻烦了. 本文介绍两个工 ...
- Java实现——Dom4j读写XML文件
1. dom4j概述 解析DOM4J是一个开源XML解析包,采用了Java集合框架并完全支持DOM,SAX和JAXP. 最大的特色是使用了大量的接口,主要接口都在org.dom4j里定义. 2. do ...
- java dom4j 读写XML
<?xml version="1.0" encoding="UTF-8"?> <Configuration> <Config id ...
- 利用dom4j读写XML
public static HashMap<String, String> ReadConfig() { HashMap<String, String> map=new Has ...
- 转:在java中使用dom4j解析xml
JAVA 使用Dom4j 解析XML Java DOM4J Parser - Parse XML Document Dom4j下载及使用Dom4j读写XML简介 在java中使用dom4j解析xml ...
随机推荐
- get请求中url传参中文乱码问题
在项目中经常会遇到中文传参数,在后台接收到乱码问题.那么在遇到这种情况下我们应该怎么进行处理让我们传到后台接收到的参数不是乱码是我们想要接收的到的,下面就是我的一些认识和理解. 一:get请求url中 ...
- 二分查找问题(Java版)
二分查找问题(Java版) 1.一般实现 package search; /** * @author lei 2011-8-17 */ public class BinarySearch ...
- Erlang中atom的实现[转]
转自: http://www.cnblogs.com/zhengsyao/p/3424539.html 在 Erlang 中,使用 atom 既方便又高效,我们就来看看 atom 是怎么实现的.ato ...
- Python 3基础教程8--if else、if elif else
本文介绍if else语句,不多说,直接看例子. if elif else语句
- Canvas 给图形绘制阴影
/** * 图形绘制阴影 */ function initDemo6() { var canvas = document.getElementById("demo6"); if ( ...
- 【java并发编程实战】第一章笔记
1.线程安全的定义 当多个线程访问某个类时,不管允许环境采用何种调度方式或者这些线程如何交替执行,这个类都能表现出正确的行为 如果一个类既不包含任何域,也不包含任何对其他类中域的引用.则它一定是无状态 ...
- UEFI
UEFI,全称Unified Extensible Firmware Interface,即“统一的可扩展固件接口”,是一种详细描述全新类型接口的标准,是适用于电脑的标准固件接口,旨在代替BIOS(基 ...
- python与MySQL数据库
python与MySQL数据库 慕课网连接 我使用的软件:python2.7 + MySQL+ Navicat for MySQL + Atom 注意:你的数据库表格类型的引擎为:InnoDB :字符 ...
- 华为手机怎么安装Google
华为手机怎么安装google 新买了个华为荣耀九,结果安装Google Play提示gms core 步骤一 gms 安装器.应用市场已经下架了 地址:链接: 点击打开链接 密码: m63j 步骤二 ...
- Apache实现一个ip(如:127.0.0.1)和多个域名(虚拟主机)绑定
今天在学习PHP时,有这样的一个需求:一个ip(如:127.0.0.1)和多个域名(虚拟主机)绑定,以下是我的解决方案:对Apache进行相关的配置 解决方案一:通过端口来区分不同的虚拟主机 ①按照绑 ...