body, table{font-family: 微软雅黑; font-size: 10pt}
table{border-collapse: collapse; border: solid gray; border-width: 2px 0 2px 0;}
th{border: 1px solid gray; padding: 4px; background-color: #DDD;}
td{border: 1px solid gray; padding: 4px;}
tr:nth-child(2n){background-color: #f8f8f8;}

//dom4j

exam.xml output.xml
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<exam>
        <student idcard="111" examid="222">
                <name>张三</name>
                <location>沈阳</location>
                <grade>89</grade>
        </student>
        <student idcard="333" examid="444">
                <name>李四</name>
                <location>大连</location>
                <grade>97</grade>
        </student>
</exam>
<?xml version="1.0" encoding="utf-8"?>
<exam>
  <student idcard="111" examid="222">
    <name>张三</name> 
    <location>沈阳</location> 
    <grade>89</grade> 
    <sex>男</sex>
  </student> 
  <student idcard="333" examid="444">
    <name>李四</name> 
    <location>大连</location>
  </student> 
  <student idcard="5555" examid="999"/>
</exam>
Dom4j.java

/*   针对exam.xml文件使用dom4j完成入下操作:
                1,得到某个具体的节点内容
                2、修改某个元素节点的主体内容
                3、向指定元素节点中增加子元素节点
                4、向指定元素节点上增加同级元素节点
                5、删除指定元素节点
                6、遍历所有元素节点
                7、获取XML文件某元素属性
*/
//开头导入包省略

public class Dom4j {
        public static void main(String[] args) throws Exception{
               SAXReader reader=new SAXReader();
                Document document=reader.read("exam.xml");    //获取document对象
                //得到第一个人的姓名
                Element rootElement = document.getRootElement();
                Element firstStudent=rootElement.element("student");
                Element firstName=firstStudent.element("name");
                String firstNameText = firstName.getText();
                System.out .println(firstNameText);

//修改第二个人的grade为100
                List allStudentList = rootElement.elements();
                Element secondStudent=(Element)allStudentList.get(1);
                Element secGrade=secondStudent.element("grade");
                secGrade.setText("100");
//第一个学生增加性别 - 男
                Element firstStuSex= firstStudent.addElement("sex");
                firstStuSex.setText("男");
//根节点增加同级元素 一个新的student
                Element createnewElement = DocumentHelper.createElement("student");
                createnewElement.setAttributeValue("idcard", "5555");
                createnewElement.setAttributeValue("examid", "999");
                rootElement.add(createnewElement);
                //rootElement.addElement("student"); //第二种方式
//删除第二个学生的grade
                secGrade.detach();              //remove()也行

    
//遍历所有元素
                for(int i=0;i<allStudentList.size();++i){
                        Element tmpStu=(Element)allStudentList.get(i);
                        for(int j=0;j<tmpStu.elements().size();j++){
                                Element tmpChild=(Element)tmpStu.elements().get(j);
                                String str=tmpChild.getName();
                                String str1=tmpChild.getText();
                                System.out .println(str+"     "+str1);
                        }
                }
 //获取XML属性
                String xmlEncoding=document.getXMLEncoding();
                String UniquePath=document.getUniquePath();
                System.out .println(xmlEncoding+"     "+UniquePath);      //在当前目录
//标准的保存语句。
//dom4j写回文档会自动写换行方便观看
                OutputFormat format = OutputFormat.createPrettyPrint();   // 指定XML编码                 
                format.setEncoding("utf-8");
                XMLWriter writer = new XMLWriter(new FileOutputStream ("output.xml"),format);
                writer.write(document);
                writer.close();
        }
}

//XPath
exam.xml         output2.xml
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<exam>
        <student idcard="111" examid="222">
                <name>张三</name>
                <location>沈阳</location>
                <grade>89</grade>
        </student>
        <student idcard="333" examid="444">
                <name>李四</name>
                <location>大连</location>
                <grade>97</grade>
        </student>
</exam>
<?xml version="1.0" encoding="utf-8"?>
<exam>
  <student idcard="111" examid="222">
    <name>张三</name> 
    <location>沈阳</location> 
    <grade>100</grade>
  </student> 
  <student idcard="333" examid="444">
    <name>李四</name> 
    <location>大连</location>
  </student>
</exam>
public class XPath {
    public static void main(String[] args) throws Exception{
        SAXReader reader = new SAXReader();
        Document document = reader.read("exam.xml");
        //得到第一个人的姓名
        Node firstStuNameNode=document.selectSingleNode("/exam/student/name");
        String firstStuName=firstStuNameNode.getText();
        System.out.println(firstStuName);
        //修改第二个人的grade为100
        Node firstStuGradeNode = document.selectSingleNode("/exam/student/grade");
        firstStuGradeNode.setText("100");
      //删除第二个学生的grade
        Node secStuNode=document.selectSingleNode("/exam/student[2]/grade");
        secStuNode.detach();
      //遍历所有元素
        List allNodes=document.selectNodes("/exam/*");
        for(int i=0;i<allNodes.size();++i){
                Element subNodes=(Element)allNodes.get(i);
                for(int j=0;j<subNodes.elements().size();++j){
                        String subName=((Element)subNodes.elements().get(j)).getName();
                        String subText=((Element)subNodes.elements().get(j)).getText();
                        System.out .println(subName+"   "+subText);
                }
        }
//标准的保存语句。
                      OutputFormat format = OutputFormat.createPrettyPrint();              
                      format.setEncoding("utf-8");
                      XMLWriter writer = new XMLWriter(new FileOutputStream ("output2.xml"),format);
                      writer.write(document);
                      writer.close();
        }
}

//目前我还只会用XPath来定位,就比DOM4j简单的多,增加还不会

dom4j+XPath的更多相关文章

  1. dom4j 通过 org.dom4j.XPath 设置命名空间来支持 带namespace 的 xpath

    测试文件 test.xml <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http:/ ...

  2. 如何使用DOM4j+xpath 解析

    1.首先去dom4j官网下载一个对应版本的JAR包 XML的配置文件 导入一个config.xml文件 下面是dom4j+xpath解析XML文件

  3. Java解析XML汇总(DOM/SAX/JDOM/DOM4j/XPath)

    [目录] 一.[基础知识——扫盲] 二.[DOM.SAX.JDOM.DOM4j简单使用介绍] 三.[性能测试] 四.[对比] 五.[小插曲XPath] 六.[补充] 关键字:Java解析xml.解析x ...

  4. JAVA与DOM解析器提高(DOM/SAX/JDOM/DOM4j/XPath) 学习笔记二

    要求 必备知识 JAVA基础知识.XML基础知识. 开发环境 MyEclipse10 资料下载 源码下载   sax.dom是两种对xml文档进行解析的方法(没有具体实现,只是接口),所以只有它们是无 ...

  5. JAVA通过XPath解析XML性能比较(原创)

    (转载请标明原文地址) 最近在做一个小项目,使用到XML文件解析技术,通过对该技术的了解和使用,总结了以下内容. 1 XML文件解析的4种方法 通常解析XML文件有四种经典的方法.基本的解析方式有两种 ...

  6. XML学习笔记(2)--dom4j操作XML

    1. 介绍(四种方式的比较这部分转载自:http://www.blogjava.net/xcp/archive/2010/02/12/312617.html) 1)DOM(JAXP Crimson解析 ...

  7. Dom4j解析Xml文件,Dom4j创建Xml文件

    Dom4j解析Xml文件,Dom4j创建Xml文件 >>>>>>>>>>>>>>>>>>&g ...

  8. java创建XML及开源DOM4J的使用

    java import java.io.File; import java.io.StringWriter; import javax.xml.parsers.DocumentBuilder; imp ...

  9. XPath详解

     xPath技术   1 引入 问题:当使用dom4j查询比较深的层次结构的节点(标签,属性,文本),比较麻烦!!! 2 xPath作用 主要是用于快速获取所需的节点对象. 3 在dom4j中如何使用 ...

随机推荐

  1. 自己写操作系统---bootsector篇

    其实博主本来想在寒假自己写一个OSkernal的,高高兴兴的影印了本<一个操作系统的实现>. 然后又去图书馆借来<30天自制操作系统>和<X86/X64体系探索编程> ...

  2. 论文笔记——NEURAL ARCHITECTURE SEARCH WITH REINFORCEMENT LEARNING

    论文地址:https://arxiv.org/abs/1611.01578 1. 论文思想 强化学习,用一个RNN学一个网络参数的序列,然后将其转换成网络,然后训练,得到一个反馈,这个反馈作用于RNN ...

  3. S3 对象

    在 R 中,S3 对象系统是一个简单且宽松的面向对象系统.每个基本对象的类型都有一个 S3 类名称.例如:integer.numeric.character.logical.list 和 data.f ...

  4. [原][译][lua][luabridge]一个简单的luabridge与c++例子结合例子

    参考:https://eliasdaler.wordpress.com/tag/luabridge/ https://eliasdaler.wordpress.com/2015/08/10/using ...

  5. 算法笔记--java的BigInteger类及BigDecimal类

    引包:import java.math.*; BigInteger类: 可以使用构造方法:public BigInteger(String val),或者valueOf(int)函数,如: BigIn ...

  6. vysor 破解 (插件 V1.7.8 客户端2.1.0)

    0.环境 mac os ===19年更新-客户端破解=== 换了个电脑,老的Chrome 插件各种问题,就换了客户端,然后就是一片模糊... 参考文档:https://www.sdbeta.com/w ...

  7. 1.python+selenium利用cookie,跳过验证码直接登录

    方法1 在登录时,叫代码等待一段时间,然后手动输入验证码 # coding:utf-8 from selenium import webdriver import time url = 'http:/ ...

  8. java 路径分隔符File.separator 以及 路径两种写法"/"和"\\"

    一.File.separator File file=new File(); 这句是新建一个文件.file.separator这个代表系统目录中的间隔符,说白了就是斜线,不过有时候需要双线,有时候是单 ...

  9. C++&C#外挂(内存修改)

    大学时候因为主修C#语言(当然现在做的是javaweb开发),那时在网上学了用C#做外挂的教程,外挂嘛,大家都懂的.这里只是低级的修改内存,不涉及到截获数据包.如果是欺骗服务器,修改服务器数据,那就难 ...

  10. SAS/SATA/SSD/IDE硬盘介绍区别

    SAS/SATA/SSD/IDE硬盘介绍区别 SAS(Serial Attached SCSI)即串行连接SCSI,是新一代的SCSI技术,和现在流行的Serial ATA(SATA)硬盘相同,都是采 ...