用dom4j增删改查xml文档------java获取xml文档的方式

为什么会有dom,dom4j这些解析xml的工具呢?下面是百度的。
Dom4j JDom等xml解析工具定义了对xml文件进行读写的一系列接口和类,并封装进一个jar文件

这样我们只需要将这个jar导入工程,就可以很方便地对XML文件进行创建、读、写等操作。这样我们就不必把精力花在研究怎么样用java打开一个xml文件,怎么样用输入流读出其内容,分析读到的内容哪部分是标签,哪部分是属性,哪部分是值,修改过的内部怎么样出输出流写回文件等等内容上。这些Dom4j等都已经做好了,你只要定义对象,调用方法就可以了。

我们能抽出更多的精力集中在XML中的数据本身上

dom4j解析xml文档

public class jdomRead {

public void parseXml(String args) throws Exception {
    //在内存中建立一个saxbuilder文档类型
    SAXBuilder saxBuilder=new SAXBuilder();
    //根据xmlfile文件创建文档
    //Document类是jdom2这个包的,不然会报错叫你转换
    Document document=saxBuilder.build(args);
    //获得文档根元素
    Element rootElement=document.getRootElement();
    System.out.println("文档根元素是:"+rootElement.getName());
    //获得根元素的所有子元素
    List<Element> childList=rootElement.getChildren();
    for(int i=0;i<childList.size();i++) {
        Element element=childList.get(i);
        System.out.println("第"+(i+1)+"个孩子节点是:"+element.getName());
    }
    //获得第2个孩子的节点
    System.out.println("第二个孩子节点的属性名和值start...:");
    Element secondChildeElement=childList.get(1);
    //获取第二个孩子节点的属性,并迭代遍历输出属性的名称,值和类型
    List<Attribute> attributes=secondChildeElement.getAttributes();
    for(int i=0;i<attributes.size();i++) {
        Attribute attribute=attributes.get(i);
        //属性名称
        System.out.println("属性名称:"+attribute.getName());
        //属性值
        System.out.println("属性值:"+attribute.getValue());
        //属性类型
        System.out.println("属性类型:"+attribute.getAttributeType());
    }
    System.out.println("第二个孩子节点的属性名和值end。。。");
    //如果第二个元素包含有子元素,继续迭代输出
    List<Element> sonElements=secondChildeElement.getChildren();
    for(int i=0;i<sonElements.size();i++) {
        Element ele=sonElements.get(i);
        System.out.println("第二个孩子的第"+(i+1)+"个子元素的名和值开始。。。");
        System.out.println("子元素名:"+ele.getName());
        System.out.println("子元素值:"+ele.getValue());
        System.out.println("第二个孩子的第"+(i+1)+"个子元素的名和值结束。。。");
    }
    
}
public static void main(String[] args) throws Exception {
    // TODO Auto-generated method stub
    jdomRead jRead=new jdomRead();
    jRead.parseXml(args[0]);

}

}
这是用args[0]获取的,要点击右键选择run---run as---run configurations
Main里的project和Mainclass就选择对应的项目名和类名,关键就是把xml复制到项目下面然后在Argument里输入src/xxx.xml
然后第二种是
SAXReader reader=new SAXReader();
Document document=reader.read(new File=("xxxx.xml"));
Element root=document.getRootElement();
parse(root);

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,026评论 19 139
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,780评论 18 399
  • JAVA面试题 1、作用域public,private,protected,以及不写时的区别答:区别如下:作用域 ...
    JA尐白阅读 1,187评论 1 0
  • 一. Java基础部分.................................................
    wy_sure阅读 3,840评论 0 11
  • 《庄子》解,每章一读。 文: 田开之见周威公。威公曰:“吾闻祝肾学生,吾子与祝肾游,亦何闻焉?”田开之曰:“开之操...
    千里飘蓬阅读 1,000评论 0 0