精彩不停!Python解析庫(kù)lxml與xpath用法總結(jié)
本文主要圍繞以xpath和lxml庫(kù)進(jìn)行展開(kāi):
一、xpath 概念、xpath節(jié)點(diǎn)、xpath語(yǔ)法、xpath軸、xpath運(yùn)算符
二、lxml的安裝、lxml的使用、lxml案例
一、xpath
1.xpath概念
XPath 是一門(mén)在 XML 文檔中查找信息的語(yǔ)言。XPath 使用路徑表達(dá)式在 XML 文檔中進(jìn)行導(dǎo)航 。XPath 包含一個(gè)標(biāo)準(zhǔn)函數(shù)庫(kù) 。XPath 是 XSLT 中的主要元素 。XPath 是一個(gè) W3C 標(biāo)準(zhǔn) 。
2.xpath節(jié)點(diǎn)
xpath有七種類(lèi)型的節(jié)點(diǎn):元素、屬性、文本、命名空間、處理指令、注釋以及文檔(根)節(jié)點(diǎn)。
節(jié)點(diǎn)關(guān)系:父、子、兄弟、先輩、后輩。
3.xpath語(yǔ)法
xpath語(yǔ)法在W3c網(wǎng)站上有詳細(xì)的介紹,這里截取部分知識(shí),供大家學(xué)習(xí)。
XPath 使用路徑表達(dá)式在 XML 文檔中選取節(jié)點(diǎn)。節(jié)點(diǎn)是通過(guò)沿著路徑或者 step 來(lái)選取的。下面列出了最有用的路徑表達(dá)式:
表達(dá)式描述nodename選取此節(jié)點(diǎn)的所有子節(jié)點(diǎn)。/從根節(jié)點(diǎn)選取。//從匹配選擇的當(dāng)前節(jié)點(diǎn)選擇文檔中的節(jié)點(diǎn),而不考慮它們的位置。.選取當(dāng)前節(jié)點(diǎn)。..選取當(dāng)前節(jié)點(diǎn)的父節(jié)點(diǎn)。@選取屬性。
在下面的表格中,我們已列出了一些路徑表達(dá)式以及表達(dá)式的結(jié)果:
路徑表達(dá)式結(jié)果bookstore選取 bookstore 元素的所有子節(jié)點(diǎn)。/bookstore選取根元素 bookstore。注釋?zhuān)杭偃缏窂狡鹗加谡备埽?/ ),則此路徑始終代表到某元素的絕對(duì)路徑!bookstore/book選取屬于 bookstore 的子元素的所有 book 元素。//book選取所有 book 子元素,而不管它們?cè)谖臋n中的位置。bookstore//book選擇屬于 bookstore 元素的后代的所有 book 元素,而不管它們位于 bookstore 之下的什么位置。//@lang選取名為 lang 的所有屬性。
謂語(yǔ)(Predicates)
謂語(yǔ)用來(lái)查找某個(gè)特定的節(jié)點(diǎn)或者包含某個(gè)指定的值的節(jié)點(diǎn)。
謂語(yǔ)被嵌在方括號(hào)中。
在下面的表格中,我們列出了帶有謂語(yǔ)的一些路徑表達(dá)式,以及表達(dá)式的結(jié)果:
路徑表達(dá)式結(jié)果/bookstore/book[1]選取屬于 bookstore 子元素的第一個(gè) book 元素。/bookstore/book[last()]選取屬于 bookstore 子元素的最后一個(gè) book 元素。/bookstore/book[last()-1]選取屬于 bookstore 子元素的倒數(shù)第二個(gè) book 元素。/bookstore/book[position()<3]選取最前面的兩個(gè)屬于 bookstore 元素的子元素的 book 元素。//title[@lang]選取所有擁有名為 lang 的屬性的 title 元素。//title[@lang='eng']選取所有 title 元素,且這些元素?fù)碛兄禐?eng 的 lang 屬性。/bookstore/book[price>35.00]選取 bookstore 元素的所有 book 元素,且其中的 price 元素的值須大于 35.00。/bookstore/book[price>35.00]/title選取 bookstore 元素中的 book 元素的所有 title 元素,且其中的 price 元素的值須大于 35.00。
選取未知節(jié)點(diǎn)
XPath 通配符可用來(lái)選取未知的 XML 元素。
通配符描述*匹配任何元素節(jié)點(diǎn)。@*匹配任何屬性節(jié)點(diǎn)。node()匹配任何類(lèi)型的節(jié)點(diǎn)。
在下面的表格中,我們列出了一些路徑表達(dá)式,以及這些表達(dá)式的結(jié)果:
路徑表達(dá)式結(jié)果/bookstore選取 bookstore 元素的所有子元素。/選取文檔中的所有元素。//title[@*]選取所有帶有屬性的 title 元素。
選取若干路徑
通過(guò)在路徑表達(dá)式中使用"|"運(yùn)算符,您可以選取若干個(gè)路徑。
在下面的表格中,我們列出了一些路徑表達(dá)式,以及這些表達(dá)式的結(jié)果:
路徑表達(dá)式結(jié)果//book/title | //book/price選取 book 元素的所有 title 和 price 元素。//title | //price選取文檔中的所有 title 和 price 元素。/bookstore/book/title | //price選取屬于 bookstore 元素的 book 元素的所有 title 元素,以及文檔中所有的 price 元素。

發(fā)表評(píng)論
請(qǐng)輸入評(píng)論內(nèi)容...
請(qǐng)輸入評(píng)論/評(píng)論長(zhǎng)度6~500個(gè)字
您提交的評(píng)論過(guò)于頻繁,請(qǐng)輸入驗(yàn)證碼繼續(xù)
圖片新聞
最新活動(dòng)更多
-
8月5日立即報(bào)名>> 【在線會(huì)議】CAE優(yōu)化設(shè)計(jì):醫(yī)療器械設(shè)計(jì)的應(yīng)用案例與方案解析
-
8月14日立即報(bào)名>> 【在線研討會(huì)】解析安森美(onsemi)高精度與超低功耗CGM系統(tǒng)解決方案
-
精彩回顧立即查看>> 《2024智能制造產(chǎn)業(yè)高端化、智能化、綠色化發(fā)展藍(lán)皮書(shū)》
-
精彩回顧立即查看>> 7月30日- 8月1日 2025全數(shù)會(huì)工業(yè)芯片與傳感儀表展
-
精彩回顧立即查看>> 全數(shù)會(huì)2025(第六屆)機(jī)器人及智能工廠展
-
精彩回顧立即查看>> OFweek 2025 具身機(jī)器人動(dòng)力電池技術(shù)應(yīng)用大會(huì)
推薦專(zhuān)題
- 1 AI產(chǎn)業(yè)的新高度!英偉達(dá)成為全球首家市值破4萬(wàn)億美元的公司
- 2 傳魏建軍與賈躍亭合作,長(zhǎng)城汽車(chē)出海美國(guó)
- 3 一文讀懂:到底什么是 “具身智能” ?
- 4 黃仁勛:與雷軍長(zhǎng)期合作,共探AI智駕
- 5 具身智能泡沫爭(zhēng)議下,華映資本尋找「穿越周期者」
- 6 中國(guó)平安們欲靠AI守“陣地”
- 7 官宣:智元機(jī)器人借殼上市,A股人形機(jī)器人第一股!
- 8 華為讓渡“三界”銷(xiāo)售主導(dǎo)權(quán),智界高管:終于能全力奔跑了
- 9 借仿生手實(shí)現(xiàn)突圍,國(guó)產(chǎn)靈巧手破局“不可能三角”
- 10 DeepSeek R2加持,中國(guó)AI與芯片產(chǎn)業(yè)迎來(lái)新一輪協(xié)同進(jìn)化