解析读取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的更多相关文章

  1. Dom4j下载及使用Dom4j读写XML简介

    sitinspring(如坐春风)原创,转载请注明作者及出处. 要使用dom4j读写XML文档,需要先下载dom4j包,dom4j官方网站在 http://www.dom4j.org/目前最新dom4 ...

  2. Dom4j下载及使用Dom4j读写XML简介(转)

    Dom4j下载及使用Dom4j读写XML简介 要使用dom4j读写XML文档,需要先下载dom4j包,dom4j官方网站在 http://www.dom4j.org/目前最新dom4j包下载地址:ht ...

  3. dom4j读写XML文档

    dom4j 最常用最简单的用法(转) 要使用dom4j读写XML文档,需要先下载dom4j包,dom4j官方网站在 http://www.dom4j.org/目前最新dom4j包下载地址:http:/ ...

  4. dom4j读写XML文件

    XML文件格式: <?xml version="1.0" encoding="UTF-8"?> <company> <employ ...

  5. 【网络爬虫】【java】微博爬虫(四):数据处理——jsoup工具解析html、dom4j读写xml

    之前提到过,对于简单的网页结构解析,可以直接通过观察法.手工写正则解析,可以做出来,比如网易微博.但是对于结构稍微复杂点的,比如新浪微博,如果还用正则,用眼睛一个个去找,未免太麻烦了. 本文介绍两个工 ...

  6. Java实现——Dom4j读写XML文件

    1. dom4j概述 解析DOM4J是一个开源XML解析包,采用了Java集合框架并完全支持DOM,SAX和JAXP. 最大的特色是使用了大量的接口,主要接口都在org.dom4j里定义. 2. do ...

  7. java dom4j 读写XML

    <?xml version="1.0" encoding="UTF-8"?> <Configuration> <Config id ...

  8. 利用dom4j读写XML

    public static HashMap<String, String> ReadConfig() { HashMap<String, String> map=new Has ...

  9. 转:在java中使用dom4j解析xml

    JAVA 使用Dom4j 解析XML Java DOM4J Parser - Parse XML Document Dom4j下载及使用Dom4j读写XML简介 在java中使用dom4j解析xml ...

随机推荐

  1. IIS发布错误记录

    1.HTTP 错误 500.19 - Internal Server Error 无法访问请求的页面,因为该页的相关配置数据无效. 详细错误信息模块 IIS Web Core 通知 BeginRequ ...

  2. 模块hashlib和logging

    Python的hashlib提供了常见的摘要算法MD5. 我们以常见的摘要算法MD5为例,计算出一个字符串的MD5值: import hashlib md5=hashlib.md5() md5.upd ...

  3. 14,flask-sqlalchemy项目配置

    基于一个flask项目,加入flask-SQLAlchemy 1.加入falsk-sqlalchemy第三方组件 from flask import Flask # 导入Flask-SQLAlchem ...

  4. 15,Flask-Script

    Flask-Script 从字面意思上来看就是 Flask 的脚本 是的,熟悉Django的同学是否还记得Django的启动命令呢? python manager.py runserver 大概是这样 ...

  5. 新浪微博API Oauth2.0 认证

    原文链接: http://rsj217.diandian.com/post/2013-04-17/40050093587 本意是在注销账号前保留之前的一些数据.决定用python 爬取收藏.可是未登录 ...

  6. WIN8、WIN7访问Windows Server 2003服务器的数据库速度很慢、远程速度很慢的解决方法

    原因是微软在WIN7开始上加入了网络速度限制.在控制台执行以下命令即可解决: netsh interface tcp set global autotuninglevel=disabled

  7. script async和defer

    1.没有async和defer,html解析时遇到script标签,会先去下载js文件,文件加载完成立即执行,执行完了再开始解析后面的html,是一个顺序流的过程 2.async,加载和渲染后续文档元 ...

  8. Swift 与众不同的地方

    Swift 与众不同的地方 switch(元组) 特点 其他语言中的switch语句只能比较离散的整形数据(字符可以转换成整数) 但是swift中可以比较整数.浮点数.字符.字符串.和元组数据类型,而 ...

  9. IntelliJ IDEA 注释模版 输入/**后 不显示配置好的模板

    简单一句话就是 当你在live templetes里配置好以后,记住abbreviation:输入框里的字母 比如我的是cc ,我要想写注释怎么办? 在方法上输入 /*cc 然后按tab键就出来了

  10. hadoop +streaming 排序总结

    参考http://blog.csdn.net/baidu_zhongce/article/details/49210787 hadoop用于对key的排序和分桶的设置选项比较多,在公司中主要以KeyF ...