XPath技术
XPath技术
基本概述
XPath即为XML路径语言,它是一种用来确定XML(标准通用标记语言的子集)文档中某部分位置的语言。XPath基于XML的树状结构,提供在数据结构树中找寻节点的能力。起初 XPath 的提出的初衷是将其作为一个通用的、介于XPointer与XSLT间的语法模型。但是 XPath 很快的被开发者采用来当作小型查询语言。
PS:其配合DOM4J解析技术,弥补了DOM4J不能跨层取元素的缺点。需要引入jaxen-1.1-beta-6.jar包。
XPath原理
XPath就好比SQL查询语句,能够对DOM树进行查询操作,并获取相应结果。
XPath案例
XML9.xml
<?xml version="1.0" encoding="utf-8"?> <AAA> <BBB id="b1">Hello World B1</BBB> <CCC id="c1"/> <BBB id="b2">Hello World B2</BBB> <BBB>Hello World B3</BBB> <DDD> <BBB id="b3">Hello World B4</BBB> </DDD> <CCC> <DDD> <BBB id="b4"/> <BBB id="b5"/> </DDD> </CCC> </AAA>
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.Attribute; 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配合xpath * */ public class XML9 { public static void main(String[] args) throws Exception { // 1.得到SAXReader解析器 SAXReader saxReader = new SAXReader(); // 2.指定解析哪个文件 Document document = saxReader.read("src/com/pc/XML9.xml"); // 3.使用XPath随意读取任何一层的元素 // document.selectNodes(); //返回多个元素 // document.selectSingleNode(); // 返回一个元素 // 取出AAA下面的所有BBB 3个 // List nodeList = document.selectNodes("/AAA/BBB"); // 取出所有的BBB 6个 // List nodeList = document.selectNodes("//BBB"); // System.out.println(nodeList.size()); // 取出AAA下面的DDD下面的最后一个BBB元素的内容 Hello World B4 // List nodeList = document.selectNodes("/AAA/DDD//BBB[last()]"); // System.out.println(((Element)nodeList.get(0)).getTextTrim()); // 取出AAA下面的CCC下面的DDD下面的所有元素 2个 // List nodeList = document.selectNodes("/AAA/CCC/DDD/*"); // 取出所有有三个祖先元素的BBB元素 // List nodeList = document.selectNodes("/*/*/*/BBB"); // System.out.println(nodeList.size()); // 取出AAA下面的第一个BBB元素的内容 Hello World B1 // List nodeList = document.selectNodes("/AAA/BBB[1]"); // System.out.println(((Element)nodeList.get(0)).getTextTrim()); // Element element = (Element) document.selectSingleNode("/AAA/BBB[1]"); // System.out.println(element.getTextTrim()); // 取出所有有id属性的元素的id属性 5个 // List nodeList = document.selectNodes("//@id"); // System.out.println(nodeList.size()); // 取出第一个有id属性的元素的id属性的值 b1 // System.out.println(((Attribute)nodeList.get(0)).getText()); // 取出所有有id属性的CCC元素 // List nodeList = document.selectNodes("//CCC[@id]"); // System.out.println(nodeList.size()); // "//BBB[@*]" 选择有任意属性的BBB元素 // "//BBB[not(@*)]" 选择没有属性的BBB元素 // "//BBB[@id='b1']" 选择含有属性id且其值为'b1'的BBB元素 // 选择含有属性id且其值(在用normalize-space函数去掉前后空格后)为'b2'的BBB元素 // "//BBB[normalize-space(@id)='b2']" // "//*[count(BBB)=2]" 选择含有2个BBB子元素的元素 // "//*[name()='BBB']" 选择所有名称为BBB的元素(这里等价于//BBB) // "//*[starts-with(name(),'B')]" 选择所有名称以"B"起始的元素 // "//*[contains(name(),'C')]" 选择所有名称包含"C"的元素 // "//*[string-length(name()) = 3]" 选择名字长度为3的元素 // "//*[string-length(name()) < 4]" 选择名字长度小于3的元素 // 同样的将<替换成大于号则是大于 // 11个 // List nodeList = document.selectNodes("//*[string-length(name()) < 4]"); // System.out.println(nodeList.size()); // "//CCC | //BBB" 选择所有的CCC和BBB元素 } }
PS:通过上述案例中的XPath语句,基本的XML查询,使用是没问题的。
以上就是XPath技术 的内容,更多相关内容请关注PHP中文网(www.php.cn)!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Kelajuan XML mudah alih ke PDF bergantung kepada faktor -faktor berikut: kerumitan struktur XML. Kaedah Penukaran Konfigurasi Perkakasan Mudah Alih (Perpustakaan, Algoritma) Kaedah Pengoptimuman Kualiti Kod (Pilih perpustakaan yang cekap, mengoptimumkan algoritma, data cache, dan menggunakan pelbagai threading). Secara keseluruhannya, tidak ada jawapan mutlak dan ia perlu dioptimumkan mengikut keadaan tertentu.

Tidak mustahil untuk menyelesaikan penukaran XML ke PDF secara langsung di telefon anda dengan satu aplikasi. Ia perlu menggunakan perkhidmatan awan, yang boleh dicapai melalui dua langkah: 1. Tukar XML ke PDF di awan, 2. Akses atau muat turun fail PDF yang ditukar pada telefon bimbit.

Ia tidak mudah untuk menukar XML ke PDF secara langsung pada telefon anda, tetapi ia boleh dicapai dengan bantuan perkhidmatan awan. Adalah disyorkan untuk menggunakan aplikasi mudah alih ringan untuk memuat naik fail XML dan menerima PDF yang dihasilkan, dan menukarnya dengan API awan. API awan menggunakan perkhidmatan pengkomputeran tanpa pelayan, dan memilih platform yang betul adalah penting. Kerumitan, pengendalian kesilapan, keselamatan, dan strategi pengoptimuman perlu dipertimbangkan ketika mengendalikan penjanaan XML dan penjanaan PDF. Seluruh proses memerlukan aplikasi front-end dan API back-end untuk bekerjasama, dan ia memerlukan pemahaman tentang pelbagai teknologi.

Permohonan yang menukarkan XML terus ke PDF tidak dapat dijumpai kerana mereka adalah dua format yang berbeza. XML digunakan untuk menyimpan data, manakala PDF digunakan untuk memaparkan dokumen. Untuk melengkapkan transformasi, anda boleh menggunakan bahasa pengaturcaraan dan perpustakaan seperti Python dan ReportLab untuk menghuraikan data XML dan menghasilkan dokumen PDF.

Untuk membuka fail web.xml, anda boleh menggunakan kaedah berikut: Gunakan editor teks (seperti Notepad atau TextEdit) untuk mengedit arahan menggunakan persekitaran pembangunan bersepadu (seperti Eclipse atau NetBeans) (Windows: Notepad Web.xml; Mac/Linux: Open -A -A TextEdit Web.xml)

Alat pemformatan XML boleh menaip kod mengikut peraturan untuk meningkatkan kebolehbacaan dan pemahaman. Apabila memilih alat, perhatikan keupayaan penyesuaian, pengendalian keadaan khas, prestasi dan kemudahan penggunaan. Jenis alat yang biasa digunakan termasuk alat dalam talian, pemalam IDE, dan alat baris arahan.

Gunakan kebanyakan editor teks untuk membuka fail XML; Jika anda memerlukan paparan pokok yang lebih intuitif, anda boleh menggunakan editor XML, seperti editor XML oksigen atau XMLSPY; Jika anda memproses data XML dalam program, anda perlu menggunakan bahasa pengaturcaraan (seperti Python) dan perpustakaan XML (seperti XML.Etree.ElementTree) untuk menghuraikan.

Terdapat dua cara untuk mengeksport XML ke PDF: menggunakan XSLT dan menggunakan perpustakaan mengikat data XML. XSLT: Buat lembaran gaya XSLT, tentukan format PDF untuk menukar data XML menggunakan pemproses XSLT. Perpustakaan mengikat data XML: Import Perpustakaan Pengikat Data XML Buat dokumen PDF Memuatkan Fail PDF Eksport Data XML. Kaedah mana yang lebih baik untuk fail PDF bergantung kepada keperluan. XSLT menyediakan fleksibiliti, manakala perpustakaan mengikat data mudah dilaksanakan; Untuk penukaran mudah, perpustakaan mengikat data lebih baik, dan untuk penukaran yang kompleks, XSLT lebih sesuai.
