(练习) dom4j对xml文档的操作和eclipse刷屏的方法


import java.awt.Robot;
import java.awt.event.InputEvent;
import java.awt.event.KeyEvent;
import java.io.File;
import java.io.FileOutputStream;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.Scanner;

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;

class Demo{
    static Document doc = DocumentHelper.createDocument();
    static Scanner scanner = new Scanner(System.in);
    static Element rootElem = doc.addElement("persons");
    public static void main(String[] args) throws Exception {
        while(true) {
        System.out.println("============");
        System.out.println("【1】添加联系人");
        System.out.println("【2】修改联系人");
        System.out.println("【3】删除联系人");
        System.out.println("【4】查询所有联系人");
        System.out.println("【5】退出程序");
        System.out.println("============");
        System.out.println("请输入您的选择");
        int n = scanner.nextInt();
        if(n==1) {
            add();
        }else if(n==2) {
            fix();
        }else if(n==3) {
            del();    
        }else if(n==4) {
            readAll();
        }else if(n==5) {
            System.exit(1);
        }
        System.out.println("输入任意数字并按回车键返回");
        scanner.nextInt();
        clear();
        }
    }
    public static void clear() throws Exception
    {
        Robot r = new Robot();
        r.mousePress(InputEvent.BUTTON3_MASK);       // 按下鼠标右键
        r.mouseRelease(InputEvent.BUTTON3_MASK);    // 释放鼠标右键
        r.keyPress(KeyEvent.VK_CONTROL);             // 按下Ctrl键
        r.keyPress(KeyEvent.VK_R);                    // 按下R键
        r.keyRelease(KeyEvent.VK_R);                  // 释放R键
        r.keyRelease(KeyEvent.VK_CONTROL);            // 释放Ctrl键
        r.delay(100);       
    }
    public static List<person> readXML() throws Exception{
        List<person> list = new ArrayList();
        Document doc = new SAXReader().read(new File("F:\\person.xml"));
        Element rootElem = doc.getRootElement();
        person p = new person();
        Iterator <Element > it = rootElem.elementIterator();
        while(it.hasNext()) {
            Element personElem = it.next();
            p.setId(personElem.attributeValue("id"));
            p.setAge(personElem.elementText("age"));
            p.setName(personElem.elementText("name"));
            p.setQq(personElem.elementText("qq"));
            p.setTel(personElem.elementText("tel"));
            list.add(p);
        }
        return list;
        
    }
    public static void addXML(List<person> list) throws Exception{
        FileOutputStream outputStream = new FileOutputStream(new File("F:\\person.xml"));
        OutputFormat format = OutputFormat.createPrettyPrint();
        format.setEncoding("utf-8");
        XMLWriter writer = new XMLWriter(outputStream, format);
        for(person p:list) {
        Element personElem = rootElem.addElement("person").addAttribute("id", p.id);
        personElem.addElement("name").setText(p.name);
        personElem.addElement("age").setText(p.age);
        personElem.addElement("tel").setText(p.tel);
        personElem.addElement("qq").setText(p.qq);
        }
        writer.write(doc);
        outputStream.close();
        
    }
    public static void add() throws Exception {
        List <person> list = readXML();
        person p = new person();
        System.out.println("请输入您的编号:");
        String id = scanner.next();
        p.setId(id);
        System.out.println("请输入您的姓名:");
        String name = scanner.next();
        p.setName(name);
        System.out.println("请输入您的年龄:");
        String age = scanner.next();
        p.setAge(age);
        System.out.println("请输入您的手机号:");
        String tel = scanner.next();
        p.setTel(tel);
        System.out.println("请输入您的qq:");
        String qq = scanner.next();
        p.setQq(qq);
        list.add(p);
        addXML(list);
        System.out.println("储存成功!");
        }
    public static void del() throws Exception {
        List <person> list = readXML();
        System.out.println("请输入您要删除的编号:");
        String id = scanner.next();
        Iterator <person>it = list.iterator();
        while(it.hasNext()) {
            person p =(person)it.next();
            if((p.id).equals(id)) {
                it.remove();
                System.out.println("删除成功!");
            }
        }
        addXML(list);
    }
    public static void readAll() throws Exception {
        List<person> list = readXML();
        for(person p:list) {
            System.out.println(p);
        }
    }
    public static void fix() throws Exception {
        List<person> list = readXML();
        System.out.println("请输入您的编号");
        String id = scanner.next();
        System.out.println("请输入您修改后的电话号码");
        String tel = scanner.next();
        Iterator<person> it= list.iterator();
        while(it.hasNext()) {
            person p = (person)it.next();
            if(p.id.equals(id)) {
                p.tel=tel;
                System.out.println("修改成功!");
            }
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
DOM和dom4j都是用于解析XML文档的工具,它们的使用方法略有不同。下面分别介绍DOM和dom4j解析XML的使用方法: 1. 使用DOM解析XML 使用DOM解析XML时,需要按照以下步骤进行: ```java // 1. 创建 DocumentBuilderFactory 对象 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); // 2. 创建 DocumentBuilder 对象 DocumentBuilder builder = factory.newDocumentBuilder(); // 3. 通过 DocumentBuilder 解析 XML 文件,得到 Document 对象 Document document = builder.parse(new File("xml文件路径")); // 4. 获取根节点 Element root = document.getDocumentElement(); // 5. 获取子节点、属性节点等 NodeList nodeList = root.getElementsByTagName("节点名称"); for (int i = 0; i < nodeList.getLength(); i++) { Node node = nodeList.item(i); if (node.getNodeType() == Node.ELEMENT_NODE) { Element element = (Element) node; // 获取子节点等操作 } else if (node.getNodeType() == Node.ATTRIBUTE_NODE) { Attr attribute = (Attr) node; // 获取属性节点等操作 } } ``` 2. 使用dom4j解析XML 使用dom4j解析XML时,需要按照以下步骤进行: ```java // 1. 读取 XML 文件 SAXReader reader = new SAXReader(); Document document = reader.read(new File("xml文件路径")); // 2. 获取根节点 Element root = document.getRootElement(); // 3. 获取子节点、属性节点等 List<Element> nodeList = root.elements("节点名称"); for (Element element : nodeList) { // 获取子节点等操作 List<Attribute> attributeList = element.attributes(); for (Attribute attribute : attributeList) { // 获取属性节点等操作 } } ``` 以上是DOM和dom4j解析XML的基本使用方法。需要注意的是,使用DOM解析XML时,由于要将整个XML文档加载到内存中,因此对于大型XML文档,可能会出现内存溢出等问题。而dom4j相对于DOM,提供了更加方便的API和更高效的内存管理方式,因此在解析大型XML文档时,dom4j可能更加适合。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值