XPath - Panduan Cepat
Sebelum mempelajari XPath, pertama-tama kita harus memahami XSL yang merupakan singkatan dari Extensible Stylesheet Lpenderitaan. Ini mirip dengan XML seperti CSS dengan HTML.
Kebutuhan XSL
Dalam hal dokumen HTML, tag sudah ditentukan sebelumnya seperti tabel, div, span, dll. Browser tahu cara menambahkan gaya ke dokumen tersebut dan menampilkannya menggunakan gaya CSS. Namun dalam kasus dokumen XML, tag tidak ditentukan sebelumnya. Untuk memahami dan mengatur gaya dokumen XML,World Wide Web Consortium (W3C)mengembangkan XSL yang dapat bertindak sebagai Bahasa Stylesheet berbasis XML. Dokumen XSL menentukan bagaimana browser harus merender dokumen XML.
Berikut adalah bagian utama XSL -
XSLT - Digunakan untuk mengubah dokumen XML menjadi berbagai jenis dokumen lainnya.
XPath - digunakan untuk menavigasi dokumen XML.
XSL-FO - digunakan untuk memformat dokumen XML.
Apa itu XPath?
XPath adalah rekomendasi resmi dari World Wide Web Consortium (W3C). Ini mendefinisikan bahasa untuk menemukan informasi dalam file XML. Ini digunakan untuk melintasi elemen dan atribut dokumen XML. XPath menyediakan berbagai jenis ekspresi yang dapat digunakan untuk menanyakan informasi yang relevan dari dokumen XML.
Structure Definitions - XPath mendefinisikan bagian-bagian dari dokumen XML seperti elemen, atribut, teks, namespace, instruksi-pemrosesan, komentar, dan node dokumen
Path Expressions - XPath menyediakan ekspresi jalur yang kuat, pilih node atau daftar node dalam dokumen XML.
Standard Functions - XPath menyediakan pustaka fungsi standar yang kaya untuk manipulasi nilai string, nilai numerik, perbandingan tanggal dan waktu, manipulasi node dan QName, manipulasi urutan, nilai Boolean, dll.
Major part of XSLT - XPath adalah salah satu elemen utama dalam standar XSLT dan harus memiliki pengetahuan agar dapat bekerja dengan dokumen XSLT.
W3C recommendation - XPath adalah rekomendasi resmi dari World Wide Web Consortium (W3C).
Seseorang harus mengingat poin-poin berikut, saat bekerja dengan XPath -
- XPath adalah komponen inti dari standar XSLT .
- XSLT tidak dapat bekerja tanpa XPath.
- XPath adalah dasar dari XQuery dan XPointer.
Ekspresi XPath umumnya mendefinisikan pola untuk memilih sekumpulan node. Pola-pola ini digunakan oleh XSLT untuk melakukan transformasi atau oleh XPointer untuk tujuan pengalamatan.
Spesifikasi XPath menentukan tujuh jenis node yang dapat menjadi output dari eksekusi ekspresi XPath.
- Root
- Element
- Text
- Attribute
- Comment
- Memproses Instruksi
- Namespace
XPath menggunakan ekspresi jalur untuk memilih node atau daftar node dari dokumen XML.
Berikut adalah daftar jalur dan ekspresi yang berguna untuk memilih node / daftar node apa pun dari dokumen XML.
S.No. | Ekspresi & Deskripsi |
---|---|
1 | node-name Pilih semua node dengan nama yang diberikan "nodename" |
2 | / Seleksi dimulai dari simpul akar |
3 | // Seleksi dimulai dari simpul saat ini yang cocok dengan pilihan |
4 | . Memilih node saat ini |
5 | .. Memilih induk dari node saat ini |
6 | @ Memilih atribut |
7 | student Contoh - Memilih semua node dengan nama "siswa" |
8 | class/student Contoh - Memilih semua elemen siswa yang merupakan anak-anak kelas |
9 | //student Memilih semua elemen siswa di mana pun mereka berada dalam dokumen |
Contoh
Dalam contoh ini, kita telah membuat contoh dokumen XML, students.xml dan dokumen stylesheetnya students.xsl yang menggunakan ekspresi XPath di bawah select atribut dari berbagai tag XSL untuk mendapatkan nilai no roll, nama depan, nama belakang, nama panggilan dan tanda dari setiap simpul siswa.
students.xml
<?xml version = "1.0"?>
<?xml-stylesheet type = "text/xsl" href = "students.xsl"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vaneet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
siswa.xsl
<?xml version = "1.0" encoding = "UTF-8"?>
<xsl:stylesheet version = "1.0"
xmlns:xsl = "http://www.w3.org/1999/XSL/Transform">
<xsl:template match = "/">
<html>
<body>
<h2>Students</h2>
<table border = "1">
<tr bgcolor = "#9acd32">
<th>Roll No</th>
<th>First Name</th>
<th>Last Name</th>
<th>Nick Name</th>
<th>Marks</th>
</tr>
<xsl:for-each select = "class/student">
<tr>
<td> <xsl:value-of select = "@rollno"/></td>
<td><xsl:value-of select = "firstname"/></td>
<td><xsl:value-of select = "lastname"/></td>
<td><xsl:value-of select = "nickname"/></td>
<td><xsl:value-of select = "marks"/></td>
</tr>
</xsl:for-each>
</table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
Verifikasi hasilnya
Dalam bab ini, kita akan melihat ekspresi XPath secara detail yang mencakup tipe umum Nodes, definisi dan pegangan XPath.
S.No. | Jenis & Deskripsi Node |
---|---|
1 | Akar Node elemen root dari Dokumen XML. |
2 | Elemen Node elemen. |
3 | Teks Teks dari node elemen. |
4 | Atribut Atribut node elemen. |
5 | Komentar Komentar |
Lokasi path menentukan lokasi node dalam dokumen XML. Jalan ini bisa absolut atau relatif. Jika jalur lokasi dimulai dengan simpul akar atau dengan '/' maka itu adalah jalur absolut. Berikut adalah beberapa contoh lokasi elemen menggunakan jalur absolut.
/class/student - pilih simpul siswa dalam simpul akar kelas.
<xsl:for-each select = "/class/student">
/class/student/firstname - pilih nama depan simpul siswa dalam simpul akar kelas.
<p><xsl:value-of select = "/class/student/firstname"/></p>
Contoh
Dalam contoh ini, kami telah membuat contoh dokumen XML students.xml dan dokumen stylesheetnya students.xsl yang menggunakan ekspresi XPath.
Berikut contoh XML yang digunakan.
students.xml
<?xml version = "1.0"?>
<?xml-stylesheet type = "text/xsl" href = "students.xsl"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vaneet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
siswa.xsl
<?xml version = "1.0" encoding = "UTF-8"?>
<xsl:stylesheet version = "1.0"
xmlns:xsl = "http://www.w3.org/1999/XSL/Transform">
<xsl:template match = "/" >
<html>
<body>
<h3>Details of each Students. </h3>
<table border = "1">
<tr bgcolor = "#9acd32">
<th>Roll No</th>
<th>First Name</th>
<th>Last Name</th>
<th>Nick Name</th>
<th>Marks</th>
</tr>
<tr>
<td><xsl:value-of select = "/class/student[1]/@rollno"/></td>
<td><xsl:value-of select = "/class/student[1]/firstname"/></td>
<td><xsl:value-of select = "/class/student[1]/lastname"/></td>
<td><xsl:value-of select = "/class/student[1]/nickname"/></td>
<td><xsl:value-of select = "/class/student[1]/marks"/></td>
</tr>
<tr>
<td>
<xsl:value-of select = "/class/student/@rollno"/>
</td>
<td><xsl:value-of select = "/class/student[2]/firstname"/></td>
<td><xsl:value-of select = "/class/student[2]/lastname"/></td>
<td><xsl:value-of select = "/class/student[2]/nickname"/></td>
<td><xsl:value-of select = "/class/student[2]/marks"/></td>
</tr>
<tr>
<td>
<xsl:value-of select = "/class/student[3]/@rollno"/>
</td>
<td><xsl:value-of select = "/class/student[3]/firstname"/></td>
<td><xsl:value-of select = "/class/student[3]/lastname"/></td>
<td><xsl:value-of select = "/class/student[3]/nickname"/></td>
<td><xsl:value-of select = "/class/student[3]/marks"/></td>
</tr>
</table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
Verifikasi hasilnya
Lokasi path menentukan lokasi node dalam dokumen XML. Jalan ini bisa absolut atau relatif. Jika jalur lokasi dimulai dengan simpul yang telah kita pilih maka itu adalah jalur relatif.
Berikut adalah beberapa contoh lokasi elemen menggunakan jalur relatif.
firstname - pilih nama depan yang terkait dengan simpul siswa.
<p><xsl:value-of select = "firstname"/></p>
Contoh
Dalam contoh ini, kami telah membuat contoh dokumen XML students.xml dan dokumen stylesheetnya students.xsl yang menggunakan ekspresi XPath.
Berikut contoh XML yang digunakan.
students.xml
<?xml version = "1.0"?>
<?xml-stylesheet type = "text/xsl" href = "students.xsl"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vaneet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
siswa.xsl
<?xml version = "1.0" encoding = "UTF-8"?>
<xsl:stylesheet version = "1.0"
xmlns:xsl = "http://www.w3.org/1999/XSL/Transform">
<xsl:template match = "/" >
<html>
<body>
<h3>Details of each Students. </h3>
<table border = "1">
<tr bgcolor = "#9acd32">
<th>Roll No</th>
<th>First Name</th>
<th>Last Name</th>
<th>Nick Name</th>
<th>Marks</th>
</tr>
<xsl:for-each select = "/class/student">
<tr>
<td><xsl:value-of select = "@rollno"/></td>
<td><xsl:value-of select = "firstname"/></td>
<td><xsl:value-of select = "lastname"/></td>
<td><xsl:value-of select = "nickname"/></td>
<td><xsl:value-of select = "marks"/></td>
</tr>
</xsl:for-each>
</table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>
Verifikasi hasilnya
Karena jalur lokasi menentukan lokasi node menggunakan jalur absolut atau relatif, sumbu digunakan untuk mengidentifikasi elemen dengan hubungannya seperti parent, child, sibling, dll. Sumbu dinamai demikian karena mengacu pada sumbu di mana elemen terletak relatif terhadap suatu elemen.
Berikut ini adalah daftar berbagai nilai sumbu.
S.No. | Sumbu & Deskripsi |
---|---|
1 | ancestor Merupakan leluhur dari simpul saat ini yang mencakup orang tua hingga simpul akar. |
2 | ancestor-or-self Mewakili node saat ini dan leluhurnya. |
3 | attribute Merupakan atribut dari node saat ini. |
4 | child Mewakili anak-anak dari node saat ini. |
5 | descendant Merupakan turunan dari node saat ini. Keturunan termasuk anak node sampai node daun (tidak ada anak lagi). |
6 | descendant-or-self Mewakili node saat ini dan turunannya. |
7 | following Merepresentasikan semua node yang muncul setelah node saat ini. |
8 | following-sibling Mewakili saudara berikut dari node konteks. Saudara kandung berada pada level yang sama dengan node saat ini dan berbagi induknya. |
9 | namespace Merupakan namespace dari node saat ini. |
10 | parent Merupakan induk dari node saat ini. |
11 | preceding Mewakili semua node yang datang sebelum node saat ini (yaitu sebelum tag pembuka). |
12 | self Merupakan node saat ini. |
Berikut adalah beberapa contoh penggunaan sumbu.
firstname - pilih nama depan yang terkait dengan simpul siswa.
<p><xsl:value-of select = "firstname"/></p>
<xsl:value-of select = "/class/student/preceding-sibling::comment()"/>
Contoh
Dalam contoh ini, kami telah membuat contoh dokumen XML students.xml dan dokumen stylesheetnya students.xsl yang menggunakan ekspresi XPath.
Berikut contoh XML yang digunakan.
students.xml
<?xml version = "1.0"?>
<?xml-stylesheet type = "text/xsl" href = "students.xsl"?>
<class>
<!-- Comment: This is a list of student -->
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vaneet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
siswa.xsl
<?xml version = "1.0" encoding = "UTF-8"?>
<xsl:stylesheet version = "1.0"
xmlns:xsl = "http://www.w3.org/1999/XSL/Transform">
<xsl:template match = "/" >
<html>
<body>
<xsl:value-of select = "/class/student/preceding-sibling::comment()"/>
<br/>
<xsl:text>First Student: </xsl:text>
<xsl:value-of select = "/class/student/child::firstname" />
</body>
</html>
</xsl:template>
</xsl:stylesheet>
Verifikasi hasilnya
Dalam bab ini, kita akan melihat operator dan fungsi XPath secara detail yang mencakup XPath yang umum digunakan defines dan handles. XPath mendefinisikan Operator dan fungsi pada tipe Node, String, Number dan Boolean.
Berikut adalah daftar yang akan kita bahas.
S.No. | Operator / Fungsi & Deskripsi |
---|---|
1 | Operator Perbandingan Operator perbandingan untuk membandingkan nilai. |
2 | Operator Boolean Operator Boolean untuk memeriksa fungsi 'dan', 'atau' & 'bukan'. |
3 | Fungsi Angka / Operator Operator / Fungsi pada angka. |
4 | Fungsi String Berbagai fungsi string. |
5 | Fungsi Node / Operator Berbagai fungsi dan operator yang bekerja pada node. |
XPath mendefinisikan wildcard berikut pada node yang akan digunakan dengan ekspresi XPath.
S.No. | WildCard & Deskripsi |
---|---|
1 | * digunakan untuk mencocokkan node mana pun. |
2 | . digunakan untuk mencocokkan node saat ini dalam konteks. |
3 | @* digunakan untuk mencocokkan atribut apa pun |
4 | node() digunakan untuk mencocokkan node jenis apa pun |
Contoh
Contoh ini membuat tabel elemen <student> dengan detailnya, dengan mengulang setiap siswa.
students.xml
<?xml version = "1.0"?>
<?xml-stylesheet type = "text/xsl" href = "students.xsl"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vaneet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
siswa.xsl
<?xml version = "1.0" encoding = "UTF-8"?>
<xsl:stylesheet version = "1.0"
xmlns:xsl = "http://www.w3.org/1999/XSL/Transform">
<xsl:template match = "/">
<html>
<body>
<h2>Students</h2>
<xsl:apply-templates select = "class/*" />
</body>
</html>
</xsl:template>
<xsl:template match = "class/*">
<xsl:apply-templates select = "@rollno" />
<xsl:apply-templates select = "firstname" />
<xsl:apply-templates select = "lastname" />
<xsl:apply-templates select = "nickname" />
<xsl:apply-templates select = "marks" />
<br />
</xsl:template>
<xsl:template match = "@rollno">
<span style = "font-size = 22px;">
<xsl:value-of select = "." />
</span>
<br />
</xsl:template>
<xsl:template match = "firstname">
First Name:<span style = "color:blue;">
<xsl:value-of select = "." />
</span>
<br />
</xsl:template>
<xsl:template match = "lastname">
Last Name:<span style = "color:green;">
<xsl:value-of select = "." />
</span>
<br />
</xsl:template>
<xsl:template match = "nickname">
Nick Name:<span style = "color:red;">
<xsl:value-of select = "." />
</span>
<br />
</xsl:template>
<xsl:template match = "marks">
Marks:<span style = "color:gray;">
<xsl:value-of select = "." />
</span>
<br />
</xsl:template>
</xsl:stylesheet>
Verifikasi hasilnya
Predikat mengacu pada ekspresi XPath yang ditulis dalam tanda kurung siku. Ini mengacu pada membatasi node yang dipilih dalam kumpulan node untuk beberapa kondisi. Sebagai contoh,
S.No. | Predikat & Deskripsi |
---|---|
1 | /class/student[1] Pilih elemen siswa pertama yang merupakan anak dari elemen kelas. |
2 | /class/student[last()] Pilih elemen siswa terakhir yang merupakan anak dari elemen kelas. |
3 | /class/student[@rolllno = 493] Pilih elemen siswa dengan rollno 493. |
4 | /class/student[marks>85] Pilih elemen siswa dengan nilai> 85. |
Contoh
Contoh ini membuat tabel elemen <student> dengan detailnya, dengan mengulang setiap siswa. Ini menghitung posisi simpul siswa dan kemudian mencetak rincian siswa bersama dengan nomor seri.
students.xml
<?xml version = "1.0"?>
<?xml-stylesheet type = "text/xsl" href = "students.xsl"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vaneet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
siswa.xsl
<?xml version = "1.0" encoding = "UTF-8"?>
<xsl:stylesheet version = "1.0"
xmlns:xsl = "http://www.w3.org/1999/XSL/Transform">
<xsl:template match = "/">
<html>
<body>
<h2>Students</h2>
<table border = "1">
<tr bgcolor = "#9acd32">
<th>Roll No</th>
<th>First Name</th>
<th>Last Name</th>
<th>Nick Name</th>
<th>Marks</th>
</tr>
<xsl:for-each select = "/class/student[1]">
<tr>
<td><xsl:value-of select = "@rollno"/></td>
<td><xsl:value-of select = "firstname"/></td>
<td><xsl:value-of select = "lastname"/></td>
<td><xsl:value-of select = "nickname"/></td>
<td><xsl:value-of select = "marks"/></td>
</tr>
</xsl:for-each>
<xsl:for-each select = "/class/student[last()]">
<tr>
<td><xsl:value-of select = "@rollno"/></td>
<td><xsl:value-of select = "firstname"/></td>
<td><xsl:value-of select = "lastname"/></td>
<td><xsl:value-of select = "nickname"/></td>
<td><xsl:value-of select = "marks"/></td>
</tr>
</xsl:for-each>
<xsl:for-each select = "/class/student[@rollno = 493]">
<tr>
<td><xsl:value-of select = "@rollno"/></td>
<td><xsl:value-of select = "firstname"/></td>
<td><xsl:value-of select = "lastname"/></td>
<td><xsl:value-of select = "nickname"/></td>
<td><xsl:value-of select = "marks"/></td>
</tr>
</xsl:for-each>
<xsl:for-each select = "/class/student[marks > 85]">
<tr>
<td><xsl:value-of select = "@rollno"/></td>
<td><xsl:value-of select = "firstname"/></td>
<td><xsl:value-of select = "lastname"/></td>
<td><xsl:value-of select = "nickname"/></td>
<td><xsl:value-of select = "marks"/></td>
</tr>
</xsl:for-each>
</table>
</body>
</html>
</xsl:template>
</xsl:stylesheet>