DOM4J解析XML

一:要导入的包
dom4j-1.6.1.jar
jaxen-1.1-bata-6.jar
二:源码
package com;
 
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.util.List;
 
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.DocumentHelper;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import org.dom4j.io.XMLWriter;
/**
* 该类主要用于测试dom4j创建xml文件和解析xml文件
* 创建xml文件: 1.通过新建document创建,如write1
* 2.解析定义好的xml字符串,如write2
* 解析xml文件:读取xml文件,通过遍历节点找到节点的属性和属性值。
* @author zhourm
*
*/
public class TestReadWrite {
public static void main(String[] args) {
TestReadWrite test = new TestReadWrite();
String roadStr = "D:/createXMLtest.xml";
//test.write1(roadStr);
test.write2(roadStr);
test.read(roadStr);
}
public void write1(String roadStr){
System.out.println("写xml方法一");
 
Document document = DocumentHelper.createDocument();
Element documentElement = document.addElement("document");
documentElement.addAttribute("action", "UP");
documentElement.addAttribute("count", "2");
documentElement.addElement("metaid").addAttribute("id", "ISBN7-200-04263-3").setText("test1");
documentElement.addElement("metaid").addAttribute("id", "u.meta2010122824-07763-1/TS·250qesu100").setText("test2");
try{
XMLWriter output = new XMLWriter(
new FileWriter( new File(roadStr) ));
output.write( document );
output.close();
}
catch(IOException e){System.out.println(e.getMessage());}
}
public void write2(String roadStr){
System.out.println("写xml方法二");
 
String xml =
"<?xml version=\"1.0\" encoding=\"UTF-8\" ?> "+
"<document action=\"UP\" count=\"2\">"+
"<metaid id=\"ISBN7-200-04263-3\" />"+
"<metaid id=\"u.meta2010122824-07763-1/TS·250qesu100\" />"+
"</document>";
 
Document document;
try {
document = DocumentHelper.parseText(xml);
try{
XMLWriter output = new XMLWriter(
new FileWriter( new File(roadStr) ));
output.write( document );
output.close();
}
catch(IOException e){System.out.println(e.getMessage());}
} catch (DocumentException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
}
public void read(String roadStr) {
//根据路径读取xml数据
File inputXml = new File(roadStr);
SAXReader saxReader = new SAXReader();
Document srcDoc;
// 解析元数据
List nodes ;
try {
srcDoc = saxReader.read(inputXml);
nodes = srcDoc.selectNodes("//metaid");
//若解析失败
if (null == nodes || nodes.isEmpty()) {
//若解析到的id为空则提示错误信息
System.out.println("解析错误");
}else{
//若解析成功
int i = 0;
for (Object obj : nodes) {
i ++;
Element metaIdElement = (Element) obj;
//获取节点的id属性值
String mataId = metaIdElement.attributeValue("id");
System.out.println("节点的属性ID取值为:"+mataId);
String mataValue = metaIdElement.getTextTrim();
System.out.println("节点的值为:"+mataValue);
}
System.out.println("获取到的节点个数为:"+i);
}
} catch (DocumentException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQLAlchemy 是一个 SQL 工具包和对象关系映射(ORM)库,用于 Python 编程语言。它提供了一个高级的 SQL 工具和对象关系映射工具,允许开发者以 Python 类和对象的形式操作数据库,而无需编写大量的 SQL 语句。SQLAlchemy 建立在 DBAPI 之上,支持多种数据库后端,如 SQLite, MySQL, PostgreSQL 等。 SQLAlchemy 的核心功能: 对象关系映射(ORM): SQLAlchemy 允许开发者使用 Python 类来表示数据库表,使用类的实例表示表中的行。 开发者可以定义类之间的关系(如一对多、多对多),SQLAlchemy 会自动处理这些关系在数据库中的映射。 通过 ORM,开发者可以像操作 Python 对象一样操作数据库,这大大简化了数据库操作的复杂性。 表达式语言: SQLAlchemy 提供了一个丰富的 SQL 表达式语言,允许开发者以 Python 表达式的方式编写复杂的 SQL 查询。 表达式语言提供了对 SQL 语句的灵活控制,同时保持了代码的可读性和可维护性。 数据库引擎和连接池: SQLAlchemy 支持多种数据库后端,并且为每种后端提供了对应的数据库引擎。 它还提供了连接池管理功能,以优化数据库连接的创建、使用和释放。 会话管理: SQLAlchemy 使用会话(Session)来管理对象的持久化状态。 会话提供了一个工作单元(unit of work)和身份映射(identity map)的概念,使得对象的状态管理和查询更加高效。 事件系统: SQLAlchemy 提供了一个事件系统,允许开发者在 ORM 的各个生命周期阶段插入自定义的钩子函数。 这使得开发者可以在对象加载、修改、删除等操作时执行额外的逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值