DOM4J的用法

原创 2017年09月13日 20:12:51
一、基本使用方式
    语法
    1、获取根元素
Element root = document.getRootElement();
    2、获取某个元素下的子元素
Element db_element = root.element("db");
    3、获取元素的子元素集合1
List<Element> db_list = db_element.elements();//所有子元素
    4、获取元素属性的值
element.attributeValue("name");
    5、获取元素的内容
element.getText();
    6、获取元素的子元素集合2
element.elements("user");//指定名称的子元素集合
    实战
<users>
<user no="2017">
<name>狗蛋</name>
<age>17</age>
</user>
<user no="2018">
<name>李狗蛋</name>
<age>19</age>
</user>
</users>

1、导入dom4j的jar包,遍历
public void test4j() throws DocumentException {
//创建解析器
    SAXReader reader = new SAXReader();
    org.dom4j.Document document = reader.read(new File("src/userInfo.xml"));
    org.dom4j.Element root = document.getRootElement();

    List<org.dom4j.Element> list = root.elements();

    for(org.dom4j.Element e:list){
//获取属性值
        String no = e.attributeValue("no");
        String name = e.element("name").getText();
        String age = e.element("age").getText();

        System.out.println(no+name+age);
    }
}


二、选择器使用
    语法
1、获取节点集合
    List<Node> list= document.selectNodes("users/user/name");
2、获取节点的节点名称
node.getName();
3、获取节点的值
node.getText();
4、获取节点的属性值
node.valuesOf("@no");

实战
2、还需导入jaxen-1.1-beta-6.jar,进行xpath操作
public void testdom4j_xpath() throws DocumentException {
    SAXReader reader = new SAXReader();
    org.dom4j.Document document = reader.read(new File("src/userInfo.xml"));
    List<Node> list= document.selectNodes("users/user/name");
    for(Node node:list){
        String qname = node.getName();
        String name = node.getText();
        System.out.println(qname+"--"+name);
    }
    List<org.dom4j.Node> list1 = document.selectNodes("users/user");
    for(Node node:list1){
        String no = node.valueOf("@no");
        System.out.println(no);
    }
}

三、创建,修改XML文档
    语法
1、获取document对象
Document document = DocumentHelper.createDocument();
2、创建根元素
 Element root = document.addElement("users");  
3、添加子节点
Element e = element.addElement("name");
4、设置属性
Element e = element.setText("张三");
5、删除节点e的子节点element
e.remove(element);

四、属性
     语法
    1.取得某节点下的某属性          
Attribute attribute=element.attribute("id");
    2.取得属性的文字
    String text=attribute.getText();
    3.删除某属性
Attribute attribute=root.attribute("size"); root.remove(attribute);
    4.遍历某节点的所有属性     
Element root=document.getRootElement();      
       for(Iterator it=root.attributeIterator();it.hasNext();){        
           Attribute attribute = (Attribute) it.next();         
           String text=attribute.getText();        
           System.out.println(text);  
          }
    5.设置某节点的属性和文字.  
newMemberElm.addAttribute("name", "sitinspring");
    6.设置属性的文字   
Attribute attribute=root.attribute("name");   attribute.setText("csdn");
五、小综合
    根据xml文档,在数据库创建表
<?xml version="1.0" encoding="UTF-8"?>
<!--
解析以下XML文档,根据配置信息要求实现:
1.连接指定数据库
2.创建table
-->
<config>
<db id="mysql">
<property name="driverClass">com.mysql.jdbc.Driver</property>
<property name="url">jdbc:mysql://127.0.0.1:3306/test</property>
<property name="user">root</property>
<property name="password">root</property>
</db>
<table tableName="tbuser">
<property name="id" column="uid" type="integer"></property>
<property name="account" column="username" type="varchar" length="255"></property>
<property name="password" column="passowrd" type="varchar" length="255"></property>
</table>
</config>

package homework;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.ArrayList;
import java.util.List;
public class CreateDB {
    String driverClass="";
    String url="";
    String user="";
    String password="";
    String tableName="";
    public static void main(String[] args) {
        try {
            new CreateDB().doit();
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } catch (SQLException e) {
            e.printStackTrace();
        } catch (DocumentException e) {
            e.printStackTrace();
        }
    }
    public String getsql() throws DocumentException {
        SAXReader reader = new SAXReader();
        Document document = reader.read("src/config.xml");
        //获取根节点
        Element root = document.getRootElement();
        //获取db节点
        Element db_element = root.element("db");
        //获取db节点里面的节点集合
        List<Element> db_list = db_element.elements();
        for(int i=0;i<db_list.size();i++){
            Element element = db_list.get(i);
            if("driverClass".equals(element.attributeValue("name"))){
                driverClass = element.getText();
            }
            else if("url".equals(element.attributeValue("name"))){
                url = element.getText();
            }
            else if("user".equals(element.attributeValue("name"))){
                user = element.getText();
            }
            else if("password".equals(element.attributeValue("name"))){
                password = element.getText();
            }
        }
        ArrayList<String> sqls = new ArrayList<>();
        //获取tableNmae节点
        Element tb_element = root.element("table");
        //获取表名称
        tableName =tb_element.attributeValue("tableName");
                //获取元素集合
        List<Element> tb_list = tb_element.elements();
        for(int i=0;i<tb_list.size();i++){
            Element element = tb_list.get(i);
            String column = element.attributeValue("column");
            if("integer".equals(element.attributeValue("type"))){
                sqls.add(column+" "+"int");
            }else if("varchar".equals(element.attributeValue("type"))){
                String lenght  = element.attributeValue("length");
                sqls.add(column+" "+" varchar("+lenght+") ");
            }
        }
        String sql="create table "+tableName+" (";
        for(int i=0;i<sqls.size();i++){
            //防止,引发的错误
            if(i!=sqls.size()-1){
                sql = sql+sqls.get(i)+" , ";
            }else {
                sql = sql+sqls.get(i);
            }
        }
        sql = sql+" );";
        return sql;
    }
    public void doit() throws ClassNotFoundException, SQLException, DocumentException {
        String sql=getsql();
        System.out.println(driverClass+"  "+url+"  "+user+" "+password);
        Class.forName(driverClass);
        Connection connection = DriverManager.getConnection(url,user,password);
        Statement statement = connection.createStatement();
        System.out.println(sql);
        statement.execute(sql);
    }
}












版权声明:本文为博主原创文章,未经博主允许不得转载。 举报

相关文章推荐

dom4j 最常用最简单的用法(转)

http://www.cnblogs.com/shitianzeng/articles/2518323.html ------------------------------------------...

dom4j 最常用最简单的用法(转)

dom4j 最常用最简单的用法(转) 要使用dom4j读写XML文档,需要先下载dom4j包,dom4j官方网站在 http://www.dom4j.org/ 目前最新dom4j包...

我是如何成为一名python大咖的?

人生苦短,都说必须python,那么我分享下我是如何从小白成为Python资深开发者的吧。2014年我大学刚毕业..

dom4j 最常用最简单的用法(转)

 要使用dom4j读写XML文档,需要先下载dom4j包,dom4j官方网站在 http://www.dom4j.org/ 目前最新dom4j包下载地址:http://nchc.dl.sour...

JAVA中使用dom4j操作XML

import java.io.File; import java.io.FileWriter; import java.io.IOException; import java.util.Iterato...

dom4j生成XML文档及解析

代码示例:import java.io.File; import java.io.FileOutputStream; import java.io.FileWriter; import java...

dom4j解析xml

解析xml文档

【JAVA学习小结】-【Dom4J解析MXL】

上一篇写了用JAXP开发包解析XML,这一篇写下用Dom4J开发包解析XML。 JAXP虽然是sun公司自己开发的解析XML开发包,但是现在主流使用的解析XML开发包都是Dom4J。 使用Dom...
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)