DOM4J的用法

一、基本使用方式

    语法

    1、获取根元素

Element root = document.getRootElement();

    2、获取某个元素下的子元素

Element db_element = root.element("db");

    3、获取元素的子元素集合1

List db_list = db_element.elements();//所有子元素

    4、获取元素属性的值

element.attributeValue("name");

    5、获取元素的内容

element.getText();

    6、获取元素的子元素集合2

element.elements("user");//指定名称的子元素集合

    实战





狗蛋

17





李狗蛋

19



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 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 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 list= document.selectNodes("users/user/name");

    for(Node node:list){

        String qname = node.getName();

        String name = node.getText();

        System.out.println(qname+"--"+name);

    }

    List 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文档,在数据库创建表









com.mysql.jdbc.Driver

jdbc:mysql://127.0.0.1:3306/test

root

root



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 db_list = db_element.elements();

        for(int i=0;i sqls = new ArrayList<>();

        //获取tableNmae节点

        Element tb_element = root.element("table");

        //获取表名称

        tableName =tb_element.attributeValue("tableName");

                //获取元素集合

        List tb_list = tb_element.elements();

        for(int i=0;i

 

 

 

 

 

 

 

 

 

 

你可能感兴趣的:(J2EE,数据库)