java dom4j html,java dom4j处理xml添加document删除document

package org.xqlee.utils.xml;

import java.util.List;

import org.dom4j.Document;

import org.dom4j.DocumentException;

import org.dom4j.DocumentHelper;

import org.dom4j.Element;

/**

*

*

*

 
 

* _________________________INFO_____________________________

* | Description : [dom4j处理xml]

* | Encoding : [UTF-8]

* | Package : [org.xqlee.utils.xml.test]

* | Project : [utils]

* | Author : [LXQ]

* | CreateDate : [2016年3月23日上午11:14:35]

* | Updater : []

* | UpdateDate : []

* | UpdateRemark: []

* | Company : [www.zhljc.com]

* | Version : [v 1.0]

* | Libs : [dom4j-1.6.1.jar xml-apis-1.0b2.jar jaxen-1.1.6.jar]

* __________________________________________________________

*

*/

public class Dom4j {

public static void main(String[] params) {

System.out.println("=====1.开始生产xml=====");

String xml = createXML();

System.out.println("=====2.结束生产xml=====");

System.out.println("=====3.第一次解析=====");

String2XML(xml);

System.out.println("=====4.第二次解析");

xml=" "+xml;//注意xml文档的<?xml version="1.0" encoding="GBK"?>前面不允许有其他值

String2XML(xml);

}

/**

* 创建xml

*

* @return xml文档字符串

*/

public static String createXML() {

System.out.println("============xml创建===============");

// 1.创建文档

Document doc = DocumentHelper.createDocument();

// 设置文件编码格式

doc.setXMLEncoding("GBK");

// 2.文档中添加节点||注意文档中只能有一个root节点

Element root = doc.addElement("ROOT");

root.addAttribute("root", "http://www.zhljc.com");

// 头部

Element header = root.addElement("HEADER");

header.addAttribute("header", "http://zhljc.com");

header.addElement("HPARAM1").addText("Header param 1");

header.addElement("HPARAM2").addText("Header param 2");

// fields

Element f1 = header.addElement("field");

f1.addAttribute("name", "F1");

f1.addText("0000f2");

Element f2 = header.addElement("field");

f2.addAttribute("name", "F2");

f2.addText("0000f2");

Element f3 = header.addElement("field");

f3.addAttribute("name", "F3");

f3.addText("0000f3");

// body

Element body = root.addElement("BODY");

body.addAttribute("body", "http://www.zhljc.com");

body.addElement("BPARAM1").addText("Body param 1");

body.addElement("BPARAM2").addText("Body param 2");

// 3.转换为字符集的xml

String xml = doc.asXML();

System.out.println("xml1:\n" + xml);

return xml;

}

/**

* 解析xml

*

* @param xml

* 字符串的xml参数

*/

public static void String2XML(String xml) {

System.out.println("============xml解析===============");

try {

// 转换

Document doc = DocumentHelper.parseText(xml);

// 获取节点内容

String headerParam1Text = doc.selectSingleNode("/ROOT/HEADER/HPARAM1").getText();

System.out.println("节点ROOT->HEADER->HPARAM1的值为:" + headerParam1Text);

@SuppressWarnings("unchecked")

List ns = doc.selectNodes("/ROOT/HEADER/field");

System.out.println("通过属性名称查询节点TEXT值:"+getTextByAttribute(ns,"name","F1"));

} catch (DocumentException e) {

System.out.println("转换异常:" + e.getMessage());

e.printStackTrace();

}

}

public static String getTextByAttribute(List nodes, String attributeName, String attributeValue) {

for (Element node : nodes) {

if (node.attributeValue(attributeName).equals(attributeValue)) {

return node.getText();

}

}

return null;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,这个问题我可以回答。以下是Java使用dom4j读取XML文件的基本步骤: 1. 导入dom4jjar包 你可以通过maven或手动下载jar包的方式导入dom4jjar包。 2. 创建SAXReader对象 SAXReader是dom4j的核心类,用于读取XML文件并将其转换为Document对象。 3. 加载XML文件 使用SAXReader对象的read方法加载XML文件,并将其转换为Document对象。 4. 获取根节点 通过Document对象的getRootElement方法获取XML文件的根节点。 5. 遍历节点 可以使用递归的方式遍历XML文件的节点,获取节点的名称、属性、子节点等信息。 下面是一个简单的示例代码: ```java import org.dom4j.Document; import org.dom4j.Element; import org.dom4j.io.SAXReader; import java.io.File; public class Dom4jDemo { public static void main(String[] args) { try { // 创建SAXReader对象 SAXReader reader = new SAXReader(); // 加载XML文件 Document document = reader.read(new File("example.xml")); // 获取根节点 Element root = document.getRootElement(); // 遍历节点 print(root); } catch (Exception e) { e.printStackTrace(); } } public static void print(Element element) { // 输出节点名称 System.out.println(element.getName()); // 输出节点属性 List<Attribute> attributes = element.attributes(); for (Attribute attribute : attributes) { System.out.println(attribute.getName() + ": " + attribute.getValue()); } // 输出子节点 List<Element> elements = element.elements(); for (Element e : elements) { print(e); } } } ``` 以上是一个简单的dom4j读取XML文件的示例代码,希望能对你有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值