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 ...
随机推荐
- 树&二叉树&哈夫曼树
1.树 需要注意的两点:n(n>=0)表示结点的个数,m表示子树的个数 (1)n>0时,树的根节点是唯一的. (2)m>0时,子树的个数没有限制. 结点的度和树的度 (1)结点的度是 ...
- Eclipse 透视图(Perspective)---Eclipse教程第06课
什么是透视图? 透视图是一个包含一系列视图和内容编辑器的可视容器.默认的透视图叫 java. Eclipse 窗口可以打开多个透视图,但在同一时间只能有一个透视图处于激活状态. 用户可以在两个透视图之 ...
- 底部菜单栏之Fragment的详细介绍和使用方法
详情请看:http://blog.csdn.net/loongggdroid/article/details/9366413
- CSS简易学习笔记
学习地址:http://www.w3school.com.cn/css/index.asp cnblog不能把格式复制上来,有格式文字版:https://github.com/songzhenhua/ ...
- finally在return之后还是之前运行
finally在运行前打印出来是return的数据,finally是最后修改的数据,如果finally存在对返回值的修改,则以finally修改的值为准. 综上所述,finally最后运行.
- LightGBM的并行优化--机器学习-周振洋
LightGBM的并行优化 上一篇文章介绍了LightGBM算法的特点,总结起来LightGBM采用Histogram算法进行特征选择以及采用Leaf-wise的决策树生长策略,使其在一批以树模型为基 ...
- 实用JS系列——面向对象中的类和继承
背景: 在最开始学习JavaScript时,我们就知道,它是一种脚本语言,也有面向对象机制.但它的面向对象继承机制是基于原型的,即Prototype.今天,我们就来找一下JS中OO的影子. 创建类 1 ...
- CSS3 em && rem 详细教程
1 # mobile css & rem & em & px > 1 rem === 16px 任意浏览器的默认字体高都是 16px, 所有未经调整的浏览器都符合: 1e ...
- hdu 2616 Kill the monster (DFS)
Kill the monster Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- CSS Sprite、CSS雪碧图应用实例
CSS Sprites技术被国内一些人称为CSS雪碧图,其实就是把网页中一些背景图片整合到一张图片文件中,再利用CSS的“background-image”,“background- repeat”, ...