詳解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檔案時,我們需要了解如何處理這些特殊字元和轉義序列。一、特殊字元和
