/**
 * XML读写示例
 * @author hx
 *
 */
public class XmlReaderWriter{
    /**
     * 读取一个XML文件,返回一个雇员链表
     * @param fileName
     * @return
     */
    public List<Employee> readXml(String fileName){
        List<Employee> employees=new ArrayList<Employee>();

        SAXReader reader = new SAXReader();
        try {
            Document  document = reader.read(new File(fileName));
            Element root = document.getRootElement();

            List nodes = root.elements("employee");

            for (Iterator it = nodes.iterator(); it.hasNext();) {
                Employee employee=new Employee();

                // 根节点下的雇员子节点
                Element employeeElm = (Element) it.next();

                // 获取雇员子节点的id属性
                Attribute attribute=employeeElm.attribute("id");
                employee.setId(Long.parseLong(attribute.getText()));// 将文本形式的long字符串还原成基本类型

                // 获得雇员子节点的名称子节点
                Element nameElm=employeeElm.element("name");
                employee.setName(nameElm.getText());// 获取名称子节点的文字

                // 获取雇员子节点的性别子节点的文字
                employee.setMale(Boolean.parseBoolean(employeeElm.element("ismale").getText()));

                // 将雇员信息放入链表
                employees.add(employee);
            }

        } catch (DocumentException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

        return employees;
    }

    /**
     * 将一个雇员链表写入XML文档
     * @param employees
     * @param fileName
     */
    public void writerToFile(List<Employee> employees,String fileName){
        // 创建文档对象
        Document document = DocumentHelper.createDocument();
        // 创建根节点
        Element root = document.addElement("employees");

        for(Employee emp:employees){
            // 创建employee节点
            Element empElm = root.addElement("employee");

            // 创建employee节点的id属性
            empElm.addAttribute("id", String.valueOf(emp.getId()));

            // 创建employee节点的子节点name
            Element nameElm = empElm.addElement("name");
            nameElm.setText(emp.getName());// 设置子节点的文字

            // 创建employee节点的子节点ismale
            Element ismaleElm = empElm.addElement("ismale");
            ismaleElm.setText(String.valueOf(emp.isMale()));// 设置子节点的文字
        }

        // 将document文档对象写入文件
        XMLWriter writer;
        try {
            writer = new XMLWriter(new FileWriter(fileName));
            writer.write(document);
            writer.close();

        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

    public static void main(String[] args){
    List<Employee> employees=new ArrayList<Employee>();
        /*employees.add(new Employee(1,"Andy",true));
        employees.add(new Employee(2,"Bill",false));
        employees.add(new Employee(3,"Cindy",true));
        employees.add(new Employee(4,"Doutglas",false));

        XmlReaderWriter xmlReaderWriter=new XmlReaderWriter();
        xmlReaderWriter.writerToFile(employees, "Employees20140724.xml");*/

        XmlReaderWriter xmlReaderWriter=new XmlReaderWriter();
        List<Employee> employee=xmlReaderWriter.readXml("Employees20140724.xml");
        employee=null;

    }
}
public class Employee{
    private long id;
    private String name;
    private boolean isMale;

    public Employee(){

    }

    public Employee(long id,String name,boolean isMale){
        this.id=id;
        this.name=name;
        this.isMale=isMale;
    }

    public long getId() {
        return id;
    }
    public void setId(long id) {
        this.id = id;
    }
    public boolean isMale() {
        return isMale;
    }
    public void setMale(boolean isMale) {
        this.isMale = isMale;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
}

这个的主要目的是让学生掌握如何导入第三方包。

爪哇国新游记之十三----XML文件读写的更多相关文章

  1. 爪哇国新游记之二十八----从url指定的地址下载文件到本地

    package download; import java.io.File; import java.io.FileOutputStream; import java.io.InputStream; ...

  2. 爪哇国新游记之三十四----Dom4j的XPath操作

    Dom4j是Java访问XML的利器之一,另一个是JDom.记得当年因为粗掌握点JDomAPI但项目要求使用Dom4j还闹一阵情绪,现在看来真是没必要,只花一些时间成本就进去一个新世界绝对是值得做的一 ...

  3. 爪哇国新游记之二十九----访问URL获取输入流

    代码: import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.FileWriter; import ...

  4. 爪哇国新游记之十四----初试JDBC

    import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import ...

  5. 爪哇国新游记之七----使用ArrayList统计水果出现次数

    之前学习制作了DArray,了解ArrayList就容易了. /** * 用于存储水果名及数量 * */ public class Fruit{ private String name; public ...

  6. 爪哇国新游记之二----用于计算三角形面积的Point类和TAngle类

    这次尝试用两个类完成一个面积计算任务: Point类代表平面上的点: public class Point { private float x; private float y; public Poi ...

  7. 爪哇国新游记之一----第一个类Cube

    将这个类作为Java学习的第一个类,简单易懂易上手. /** * 正方体类 */ public class Cube { private int length;// 正方体边长 private sta ...

  8. 爪哇国新游记之二十二----排序判断重复时间复杂度为2n的位图法

    import java.util.ArrayList; import java.util.List; /** * 位图法 * 用于整型数组判重复,得到无重复列表 * */ public class B ...

  9. 爪哇国新游记之十九----使用Stack检查数字表达式中括号的匹配性

    /** * 辅助类 * 用于记载字符和位置 * */ class CharPos{ char c; int pos; public CharPos(char c,int pos){ this.c=c; ...

随机推荐

  1. 部署openstack(N)版本-本地yum源(1)

    部署本地openstack yum源,原因主要是我想安装老版本,N版(newton),部署本地yum源,安装速度可以更快. 1. 使用apache提供yum服务 yum install -y http ...

  2. python 自定义过滤器

    文件目录结构: 新建文件并且命名为“templatetags” , 然后复制 __init__.py文件,拷贝到templatetags文件夹里, __pycache__文件夹可以忽略哈,那是程序运行 ...

  3. (7) go 函数

    1.格式 调用 2.包 (1)包 本质 文件夹.每一个文件都必须属于一个包 (2)给包取别名 (3)函数的首字母大小,决定是否能被外包访问 (3) 3.多返回值 4.递归 5.基本数据类型和数组都是拷 ...

  4. POJ2828 Buy Tickets [树状数组,二分答案]

    题目传送门 Buy Tickets Time Limit: 4000MS   Memory Limit: 65536K Total Submissions: 22611   Accepted: 110 ...

  5. java过滤敏感词汇

    前言 现在几乎所有的网站再发布带有文字信息的内容时都会要求过滤掉发动的.不健康的.影响社会安定的等敏感词汇,这里为大家提供了可以是现在这种功能的解决方案 第一种方式 创建敏感词汇文件:首先需要准备一个 ...

  6. 洛谷——P1744 采购特价商品

    P1744 采购特价商品 题目背景 <爱与愁的故事第三弹·shopping>第一章. 题目描述 中山路店山店海,成了购物狂爱与愁大神的“不归之路”.中山路上有n(n<=100)家店, ...

  7. XJTUOJ wmq的队伍(树状数组求 K 元逆序对)

    题目链接:http://oj.xjtuacm.com/problem/14/[分析]二元的逆序对应该都会求,可以用树状数组.这个题要求K元,我们可以看成二元的.我们先从后往前求二元逆序对数, 然后对于 ...

  8. Redux 和 Redux thunk 理解

    1: state 就像 model { todos: [{ text: 'Eat food', completed: true }, { text: 'Exercise', completed: fa ...

  9. 【二分】Codeforces Round #435 (Div. 2) D. Mahmoud and Ehab and the binary string

    题意:交互题:存在一个至少有一个0和一个1的长度为n的二进制串,你可以进行最多15次询问,每次给出一个长度为n的二进制串,系统返回你此串和原串的海明距离(两串不同的位数).最后要你找到任意一个0的位置 ...

  10. Android Studio自动化快速实现Parcelable接口序列化

    1.在线安装 然后打开File -> Settings -> Pugins -> Browse Repositories 如下,输入android parcelable code g ...