>백엔드 개발 >XML/RSS 튜토리얼 >XML 프로그래밍-DOM4J

XML 프로그래밍-DOM4J

黄舟
黄舟원래의
2017-02-20 15:13:521374검색

XML프로그래밍-DOM4J

기본 개요


dom4jJavaXML API이며 jdom, XML 파일을 읽고 쓰는 데 사용됩니다. dom4j는 탁월한 성능, 강력한 기능 및 사용하기 매우 쉬운 특성을 지닌 매우 뛰어난 JavaXML API입니다. 또한 오픈 소스 소프트웨어인 SourceForge에서 찾을 수 있습니다. 또한 주류 Java XML API 리뷰의 성능, 기능 및 사용 용이성에 대한 IBM DeveloperWorks 기사를 찾을 수도 있습니다. dom4j가 모든 면에서 우수하다는 것을 알 수 있습니다. 오늘날 우리는 점점 더 많은 Java 소프트웨어가 dom4j를 사용하여 XML, SunJAXMdom4j를 사용하고 있다는 점은 특히 언급할 가치가 있습니다. . 이것은 이미 필수 jar 패키지이며, Hibernate에서도 구성 파일을 읽고 쓰는 데 사용됩니다. PS:

DOM4J 이 강력한 이유 중 하나는 XPath를 지원한다는 것입니다. Technology, DOM4J에도 해당 참조 문서가 있으므로 필요한 경우 검색하고 다운로드할 수 있습니다.

DOM4J

가 있나요?

이전 블로그에서 설명한 두 기술, DOM

SAX 기술 중 전자의 단점은 시간이 많이 걸리는 메모리라는 점에서 후자의 단점은 읽기 작업만 수행할 수 있는 반면 DOM4J는 효율성을 제출하고 crud 운영 . PS:

DOM4J

를 사용하려면 해당 기본 JAR을 가져와야 합니다. 🎜> 패키지, DOM4J의 확장 기능을 사용하는 경우 확장 JAR 패키지도 import해야 합니다.

DOM4J시작하기

DOM4JDocument 객체

를 얻는 세 가지 방법 1.XML 파일을 읽고, 문서 객체 얻기(자주 사용하는)

    SAXReader reader = new SAXReader();
    Document   document = reader.read(new File(“src/input.xml"));

2.XML 텍스트를 , 형식으로 구문 분석하여 문서객체
    String text = "<members></members>";
    Document document = DocumentHelper.parseText(text);

3.

적극적으로 문서객체
    Document document = DocumentHelper.createDocument();
    //创建根节点
    Element root = document.addElement("members");

PS

: 해당 JAR 패키지를 가져와야 합니다.



노드 객체

1

, 문서의 루트 노드 가져오기

    Element root = document.getRootElement();



2

, 노드의 하위 노드 가져오기


    Element element=node.element(“书名");

3

, 노드의 콘텐츠를 가져옵니다.

    String text1=node.getText();
    String text2=node.getTextTrim();	// 去掉内容前面和后面的空格
4

, 노드 아래의 모든 이름을 가져옵니다. "

member" 하위 노드를 탐색하고
    List nodes = rootElm.elements("member");
    for (Iterator it = nodes.iterator(); it.hasNext();) {
          Element elm = (Element) it.next();
          // do something
    }
5

를 탐색하고 특정 노드

    for(Iterator it=root.elementIterator();it.hasNext();){
        Element element = (Element) it.next();
           // do something
      }
6, 노드

    Element ageElm = newMemberElm.addElement("age");
7 아래에 하위 노드 추가, 노드 텍스트 설정

    element.setText("29");
8, 노드

    //childElm是待删除的节点,parentElm是其父节点
    parentElm.remove(childElm);
9 삭제,

CDATA 노드
    Element contentElm = infoElm.addElement("content");
    contentElm.addCDATA(diary.getContent());

추가


PS

: 레이어를 넘어 노드에 액세스할 수 없다는 점에 유의하세요.

노드 객체 속성

1

, 특정 노드 아래의 속성 가져오기

    Element root=document.getRootElement();    
      //属性名name
    Attribute attribute=root.attribute("size");
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("sitinspring");

지정된 위치에 노드 삽입

1.

삽입 위치의 노드 목록 가져오기(

list) 2.

list.add(index,element)

를 호출하고 index에 따라 결정됩니다. 요소 삽입 위치. Element 요소는

DocumentHelper

개체를 통해 얻을 수 있습니다. 샘플 코드:

    Element aaa = DocumentHelper.createElement("aaa");
    aaa.setText("aaa");
    List list = root.element("书").elements();
    list.add(1, aaa);
    //更新document

XML

파일

1

, 문서 전체가 영어로 작성된 경우


XMLWriter writer = new XMLWriter(new  FileWriter("output.xml"));
writer.write(document);
writer.close();

2、如果文档含有中文

OutputFormat outputFormat = OutputFormat.createPrettyPrint();
outputFormat.setEncoding("utf-8");

XMLWriter xmlWriter = new XMLWriter(new FileOutputStream("src/com/pc/XML8.xml"), outputFormat);
xmlWriter.write(document);
xmlWriter.close();

PS:出现乱码的原因是因为输出字符集不能识别中文,这样可以通过OutputFormatsetEncoding方法设置为UTF-8,然后再使用XMLWriter这种形参的(OutputStream out, OutputFormat format) 构造方构造方法,就能解决乱码问题了,至于为什么会用createPrettyPrint方法,是因为这样做输出的格式更符合人的阅读习惯。


综合案例

XML8.xml

<?xml version="1.0" encoding="utf-8"?>
<班级 班次="1班" 编号="C1">
	<学生 学号="n1" 性别="男" 授课方式="面授" 朋友="n2" 班级编号="C1">
		<名字>张三</名字>
		<年龄>20</年龄>
		<介绍>不错</介绍>
	</学生>
	<学生 学号="n2" 性别="女" 授课方式="面授" 朋友="n1 n3" 班级编号="C1">
		<名字>李四</名字>
		<年龄>18</年龄>
		<介绍>很好</介绍>
	</学生>
	<学生 学号="n3" 性别="男" 授课方式="面授" 朋友="n2" 班级编号="C1">
		<名字>王五</名字>
		<年龄>22</年龄>
		<介绍>非常好</介绍>
	</学生>
	<学生 性别="男" 班级编号="C1">
		<名字>小明</名字>
		<年龄>30</年龄>
		<介绍>好</介绍>
	</学生>
</班级>


package com.pc;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.FileWriter;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.Iterator;
import java.util.List;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.OutputFormat;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
/**
 * 
 * @author Switch
 * @function 使用DOM4j解析XML文件
 * 
 */
public class XML8 {
	// 使用DOM4j对XML进行CRUD操作
	public static void main(String[] args) throws Exception {
		// 1.得到解析器
		SAXReader saxReader = new SAXReader();
		// 2.指定解析哪个XML文件
		Document document = saxReader.read(new File("src/com/pc/XML8.xml"));
		// list(document.getRootElement());
		// read(document);
		// readByXPath(document);
		// add(document);
		// delete(document);
		// updateElement(document);
		// updateAttribute(document);
		// addByIndex(document, 3);
	}

	// 更新属性(修改所有班级编号为C2)
	public static void updateAttribute(Document document) throws Exception {
		// 得到所有学生
		List<Element> students = document.getRootElement().elements("学生");
		for (Element e : students) {
			// 修改班级编号
			e.addAttribute("班级编号", "C2");
		}
		updateToXML(document);
	}

	// 更新元素(将所有学生的年龄+3)
	public static void updateElement(Document document) throws Exception {
		// 得到所有学生
		List<Element> students = document.getRootElement().elements("学生");
		for (Element e : students) {
			// 取出年龄
			Element age = e.element("年龄");
			age.setText(Integer.parseInt(age.getTextTrim()) + 3 + "");
		}
		updateToXML(document);
	}

	// 删除元素(删除第一个学生)
	public static void delete(Document document) throws Exception {
		// 找到元素
		Element stu = document.getRootElement().element("学生");
		// 删除
		stu.getParent().remove(stu);

		// 更新
		updateToXML(document);
	}

	// 添加元素到指定位置
	public static void addByIndex(Document document, int index)
			throws Exception {
		// 创建一个元素
		Element newStu = DocumentHelper.createElement("学生");
		newStu.setText("小花");
		// 得到所有学生的list
		List<Element> students = document.getRootElement().elements("学生");
		// 按索引添加
		students.add(index, newStu);

		// 更新
		updateToXML(document);
	}

	// 添加元素(添加一个学生到xml中)
	public static void add(Document document) throws Exception {
		// 创建一个学生节点对象

		Element newStu = DocumentHelper.createElement("学生");
		// 给元素添加属性
		newStu.addAttribute("学号", "n4");
		Element newStuName = DocumentHelper.createElement("名字");
		Element newStuAge = DocumentHelper.createElement("年龄");
		Element newStuIntro = DocumentHelper.createElement("介绍");

		// 把子元素挂载到学生节点下
		newStu.add(newStuName);
		newStu.add(newStuAge);
		newStu.add(newStuIntro);
		// 将学生挂载在根节点下
		document.getRootElement().add(newStu);

		// 更新
		updateToXML(document);
	}

	private static void updateToXML(Document document)
			throws UnsupportedEncodingException, FileNotFoundException,
			IOException {
		// 更新xml文件
		// 直接输出会出现中文乱码
		OutputFormat outputFormat = OutputFormat.createPrettyPrint();
		outputFormat.setEncoding("utf-8");

		XMLWriter xmlWriter = new XMLWriter(new FileOutputStream(
				"src/com/pc/XML8.xml"), outputFormat);
		xmlWriter.write(document);
		xmlWriter.close();
	}

	// xpath技术,跨层读取某个元素
	public static void readByXPath(Document document) throws Exception {
		// 取出第一个学生
		Element student = (Element) document.selectSingleNode("/班级/学生[1]");
		System.out.println("姓名:" + student.elementText("名字") + "\t年龄:"
				+ student.elementText("年龄") + "\t介绍:"
				+ student.elementText("介绍") + "\t性别:"
				+ student.attributeValue("性别"));
	}

	// 读取指定的某个元素(读取第一个学生的信息)
	public static void read(Document document) throws Exception {
		// 得到根元素
		Element root = document.getRootElement();
		// root.elements("学生"); 取出root元素下的所有学生元素
		// root.element("学生"); 取出root元素下的第一个学生元素
		// 取出root元素下的第一个学生元素
		Element student = (Element) root.elements("学生").get(0);
		System.out.println("姓名:" + student.elementText("名字") + "\t年龄:"
				+ student.elementText("年龄") + "\t介绍:"
				+ student.elementText("介绍") + "\t性别:"
				+ student.attributeValue("性别"));
	}

	// 遍历xml文件
	public static void list(Element element) {
		System.out.println("元素名称:" + element.getName() + "\t元素内容:"
				+ element.getTextTrim());

		Iterator<Element> iterator = element.elementIterator();

		while (iterator.hasNext()) {
			Element e = iterator.next();
			// 递归
			list(e);
		}
	}
}

 以上就是XML编程-DOM4J的内容,更多相关内容请关注PHP中文网(www.php.cn)!


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
이전 기사:XML 프로그래밍-SAX다음 기사:XML 프로그래밍-SAX