zoukankan      html  css  js  c++  java
  • [JavaWeb基础] 030.dom4j读取xml的4种方法

    通常我们在项目开发的过程中经常要操作到xml文件,在JAVA这边,我们会很自然的联想到Dom4J这个apache的开源插件,那么我们使用Dom4J如何来读取xml文件呢?下面我们来看看以下4种方法

    1.第一种方法:使用dom4j 中saxreader 获取Document容器,利用此容器的elementIterator读取xml文件

    public static void readXML() throws DocumentException{
      
    	// 获取读取xml的对象。
    	SAXReader sr = new SAXReader();
    	// 得到xml所在位置。然后开始读取。并将数据放入doc中
    	Document doc = sr.read("src/com/sinojava/EMP.xml");
    	// 向外取数据,获取xml的根节点。
    	Element el_root = doc.getRootElement();
    	// 从根节点下依次遍历,获取根节点下所有子节点
    	Iterator it = el_root.elementIterator();
      
    	// 遍历该子节点
    	while(it.hasNext()){
    		// 再获取该子节点下的子节点
    		Object o = it.next();
    		Element el_row = (Element)o;
    		String s = el_row.getText();
    	
    		Iterator it_row = el_row.elementIterator();
    	    
    		// 遍历节点
    		while(it_row.hasNext()){
    			// 获取该节点下的所有数据。
    			Element el_ename = (Element)it_row.next();
    			System.out.println(el_ename.getText());
    		}
    	}
    }
    

     2.第二种方法:使用elements方法进行xml的读取,相当于条件查询,可以根据不同的节点,利用for循环查询该节点下所有的数据

    public static void readXML02() throws DocumentException{
    	// 获取读取方式
    	SAXReader sr = new SAXReader();
    	// 读取xml文件,并且将数据全部存放到Document中
    	Document doc = sr.read("src/com/sinojava/EMP.xml");
    	// 获取根节点
    	Element root = doc.getRootElement();
    	// 根据根节点,将根节点下 row中的所有数据放到list容器中。
    	List list = root.elements("ROW");
    	
    	// 这种遍历方式,是jdk1.5以上的版本支持的遍历方式
    	for(Object obj:list){
    		Element row = (Element)obj;
    		
    		// 获取ENAME节点下所有的内容,存入list_row容器中
    		List list_row = row.elements("ENAME");
    		for(Object objempno:list_row){
    			Element el_empno = (Element)objempno;
    			// 获取节点下的数据。
    			System.out.println(el_empno.getName()+": "+el_empno.getText());
    		}
    	}
    }
    

    3. 第三种方法:使用适配器来完成xml的读取。

     public static void readXML04() throws DocumentException{
      
    	 SAXReader sr = new SAXReader();
    	 Document doc = sr.read("src/com/sinojava/EMP.xml");
    	 // 使用观察器的子类,来完成对xml文件的读取。
    	 doc.accept(new VisitorSupport() {
    		 // 利用观察期进行xml的读取。
    		 public void visit(Element el) {
    			 System.out.println(el.getName()+": "+el.getText());
    		 }
    	 });
     }
    

     4.第四种方法:使用selectNodes读取xml文件

    public static void readXML05(String elementpath) throws DocumentException{
    	SAXReader sr = new SAXReader();
    	Document doc = sr.read("src/com/sinojava/EMP.xml");
    	// 使用selectNodes获取所要查询xml的节点。
    	List list = doc.selectNodes(elementpath);
    	// 遍历节点,获取节点内数据。
    	for(Object obj:list){
    	   Element el = (Element)obj;
    	   System.out.println(el.getText());
    	}
    }
    

     

    本站文章为 宝宝巴士 SD.Team 原创,转载务必在明显处注明:(作者官方网站: 宝宝巴士 

    转载自【宝宝巴士SuperDo团队】原文链接: http://www.cnblogs.com/superdo/p/50080313.html

  • 相关阅读:
    Vue's Demo
    安装informatic过程中的错误
    linux系统字符集
    netstat
    查看linux系统的信息
    以太坊私有链的搭建
    $0 $1
    WordPaster-Joomla_3.4.7-tinymce 4.1.7示例发布
    Joomla3x-CKEditor4x-WordPaster整合示例
    Firefox 43无法安装xpi的问题
  • 原文地址:https://www.cnblogs.com/superdo/p/5080313.html
Copyright © 2011-2022 走看看