详解dom4j操作带冒号的xml示例代码
这几天被同事问道是否可以用dom4j来操作代用命名空间的xml(类似:
由于没有研究过,同事决定使用java自带的api来编写。
今天有时间变查了一下资料,后来发现dom4j完全可以胜任这项工作。网上有很多代码,看来看去云里雾里的。后来看到一个网友写到(直接用冒号后边的标签就能取到),试了一下,果真可以。
下面写了一个测试例子,有xml的读写操作。有兴趣的朋友可以参考,代码比较简单,就不过多的介绍。
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.Namespace; import org.dom4j.io.SAXReader; import org.dom4j.io.XMLWriter; import org.junit.Test; public class TestOperXML { //@Test public void testOfReader(){ String fileName = "D:\\tb_user1.xml"; SAXReader reader = new SAXReader(); try { Document doc = reader.read(new File(fileName)); Element root = doc.getRootElement(); Element content = root.element("XMI.content"); println(content.getName()); Element catalog = content.element("Catalog"); println(catalog.getName()); Namespace np = catalog.getNamespace(); println(catalog.getNamespace().getPrefix()); println("xmi.id:"+catalog.attribute("xmi.id").getText()); println("name:"+catalog.attribute("name").getText()); println("visibility:" + catalog.attribute("visibility").getText()); } catch (DocumentException e) { e.printStackTrace(); } } //@Test public void testOfWriter(){ Document doc = DocumentHelper.createDocument(); Element root = doc.addElement("XMI"); root.addNamespace("CWM", "org.omg.CWM1.0").addNamespace("CWMRDB", "org.omg.CWM1.0/Relational") .addNamespace("CWMOLAP", "org.omg.CWM1.0/OLAP").addNamespace("CWMTFM", "org.omg.CWM1.0/Transformation") .addAttribute("xmi.version", "1.1").addAttribute("timestamp", "5月 23 2016 13:10:03"); Element xmlHeader = root.addElement("XMI.header"); Element documentation = xmlHeader.addElement("XMI.documentation"); documentation.addElement("XMI.exporter").setText("Meta Integration Model Bridge"); documentation.addElement("XMI.exporterVersion").setText("6.0.3 - Jan 28 2009 18:35:56"); xmlHeader.addElement("metamodel").addAttribute("xmi.name", "CWM").addAttribute("xmi.version", "1.0"); Element content = root.addElement("XMI.content"); Element catalog = content.addElement("CWMRDB:Catalog").addAttribute("xmi.id", "_4").addAttribute("name", "Model_1") .addAttribute("visibility", "public"); catalog.addNamespace("CWMRDB", "org.omg.CWM1.0/Relational"); Element schema = catalog.addElement("CWM:Namespace.ownedElement").addNamespace("CWM", "org.omg.CWM1.0").addElement("Schema"); schema.addNamespace("CWMRDB", "org.omg.CWM1.0/Relational"); schema.addElement("CWM:Namespace.ownedElement").addNamespace("CWM", "org.omg.CWM1.0"); try { XMLWriter writer = new XMLWriter(new FileWriter("out.xml")); writer.write(doc); writer.close(); } catch (IOException e) { e.printStackTrace(); } } @Test public void testOfXPath(){ String fileName = "D:\\tb_user1.xml"; SAXReader reader = new SAXReader(); try { Document doc = reader.read(new File(fileName)); List list = doc.selectNodes("//XMI/XMI.content/CWMRDB:Catalog"); for(Object o : list){ Element ele = (Element)o; println(ele.getName()); List list1 = ele.selectNodes("//CWMRDB:Catalog"); println(list1); } }catch(Exception e){ e.printStackTrace(); } } private void println(Object o){ if(o == null){ System.out.println(":>> null "); }else{ System.out.println(":>> "+o.toString()); } } }
xml代码:
<?xml version="1.0" encoding="utf-8"?> <XMI xmlns:CWM="org.omg.CWM1.0" xmlns:CWMRDB="org.omg.CWM1.0/Relational" xmlns:CWMOLAP="org.omg.CWM1.0/OLAP" xmlns:CWMTFM="org.omg.CWM1.0/Transformation" xmi.version="1.1" timestamp="5月 23 2016 13:10:03"> <XMI.header> <XMI.documentation> <XMI.exporter>Meta Integration Model Bridge</XMI.exporter> <XMI.exporterVersion>6.0.3 - Jan 28 2009 18:35:56</XMI.exporterVersion> </XMI.documentation> <XMI.metamodel xmi.name="CWM" xmi.version="1.0"/> </XMI.header> <XMI.content> <CWMRDB:Catalog xmi.id="_4" name="Model_1" visibility="public"> <CWM:Namespace.ownedElement> <CWMRDB:Schema xmi.id="_5" name="unnamed_5" visibility="public" namespace="_4"> <CWM:Namespace.ownedElement></CWM:Namespace.ownedElement> </CWMRDB:Schema> </CWM:Namespace.ownedElement> </CWMRDB:Catalog> <CWM:Catalog></CWM:Catalog> </XMI.content> </XMI>
以上是详解dom4j操作带冒号的xml示例代码的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

XML文件可以用PPT打开吗?XML,即可扩展标记语言(ExtensibleMarkupLanguage),是一种被广泛应用于数据交换和数据存储的通用标记语言。与HTML相比,XML更加灵活,能够定义自己的标签和数据结构,使得数据的存储和交换更加方便和统一。而PPT,即PowerPoint,是微软公司开发的一种用于创建演示文稿的软件。它提供了图文并茂的方

使用Python实现XML数据的合并和去重XML(eXtensibleMarkupLanguage)是一种用于存储和传输数据的标记语言。在处理XML数据时,有时候我们需要将多个XML文件合并成一个,或者去除重复的数据。本文将介绍如何使用Python实现XML数据的合并和去重的方法,并给出相应的代码示例。一、XML数据合并当我们有多个XML文件,需要将其合

使用Python实现XML数据的筛选和排序引言:XML是一种常用的数据交换格式,它以标签和属性的形式存储数据。在处理XML数据时,我们经常需要对数据进行筛选和排序。Python提供了许多有用的工具和库来处理XML数据,本文将介绍如何使用Python实现XML数据的筛选和排序。读取XML文件在开始之前,我们需要先读取XML文件。Python有许多XML处理库,

Python中的XML数据转换为CSV格式XML(ExtensibleMarkupLanguage)是一种可扩展标记语言,常用于数据的存储和传输。而CSV(CommaSeparatedValues)则是一种以逗号分隔的文本文件格式,常用于数据的导入和导出。在处理数据时,有时需要将XML数据转换为CSV格式以便于分析和处理。Python作为一种功能强大

使用PHP将XML数据导入数据库引言:在开发中,我们经常需要将外部数据导入到数据库中进行进一步的处理和分析。而XML作为一种常用的数据交换格式,也经常被用来存储和传输结构化数据。本文将介绍如何使用PHP将XML数据导入数据库。步骤一:解析XML文件首先,我们需要解析XML文件,提取出需要的数据。PHP提供了几种解析XML的方式,其中最常用的是使用Simple

Python实现XML和JSON之间的转换导语:在日常的开发过程中,我们常常需要将数据在不同的格式之间进行转换。XML和JSON是常见的数据交换格式,在Python中,我们可以使用各种库来实现XML和JSON之间的相互转换。本文将介绍几种常用的方法,并附带代码示例。一、XML转JSON在Python中,我们可以使用xml.etree.ElementTree模

使用Python处理XML中的错误和异常XML是一种常用的数据格式,用于存储和表示结构化的数据。当我们使用Python处理XML时,有时可能会遇到一些错误和异常。在本篇文章中,我将介绍如何使用Python来处理XML中的错误和异常,并提供一些示例代码供参考。使用try-except语句捕获XML解析错误当我们使用Python解析XML时,有时候可能会遇到一些

Python解析XML中的特殊字符和转义序列XML(eXtensibleMarkupLanguage)是一种常用的数据交换格式,用于在不同系统之间传输和存储数据。在处理XML文件时,经常会遇到包含特殊字符和转义序列的情况,这可能会导致解析错误或者误解数据。因此,在使用Python解析XML文件时,我们需要了解如何处理这些特殊字符和转义序列。一、特殊字符和
