欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python使用xpath獲取頁(yè)面元素的使用

 更新時(shí)間:2021年09月10日 12:02:19   作者:Sun@Python  
本文主要介紹了python使用xpath獲取頁(yè)面元素的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

關(guān)于python 使用xpath獲取網(wǎng)頁(yè)信息的方法?

1、xpath的使用方法?

​ XPath 使用路徑表達(dá)式來(lái)選取 XML 文檔中的節(jié)點(diǎn)或節(jié)點(diǎn)集。節(jié)點(diǎn)是通過(guò)沿著路徑 (path) 或者步 (steps) 來(lái)選取的。

常用路徑表達(dá)式含義

表達(dá)式 描述
/ 從根節(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)。
@ 選取屬性
* 表示任意內(nèi)容(通配符)
| 運(yùn)算符可以選取多個(gè)路徑

常用功能函數(shù)

函數(shù) 用法 解釋
startswith() xpath(‘//div[starts-with(@id,”ma”)]‘) #選取id值以ma開(kāi)頭的div節(jié)點(diǎn)
contains() xpath(‘//div[contains(@id,”ma”)]‘) #選取id值包含ma的div節(jié)點(diǎn)
and() xpath(‘//div[contains(@id,”ma”) and contains(@id,”in”)]‘) #選取id值包含ma的div節(jié)點(diǎn)
text() _.xpath('./div/div[4]/a/em/text()') #選取em標(biāo)簽下文本內(nèi)容

備注:

1、html中當(dāng)相同層次存在多個(gè)標(biāo)簽例如div,它們的順序是從1開(kāi)始,不是0
2、瀏覽器中使用開(kāi)發(fā)者工具可以快速獲取節(jié)點(diǎn)信息

在這里插入圖片描述

2、實(shí)例:

#!/usr/bin/python3
# -*- coding: utf-8 -*-
# @Time    : 2021/9/7 9:35
# @Author  : Sun
# @Email   : 8009@163.com
# @File    : sun_test.py
# @Software: PyCharm


import requests
from lxml import etree


def get_web_content():
    try:
        url = "htpps://***keyword=%E6%97%A0%E9%92%A2%E5%9C%88&wq=%E6%97%A0%E"
  "9%92%A2%E5%9C%88&ev=1_68131%5E&pvid=afbf41410b164c1b91d"
        "abdf18ae8ab5c&page=5&s=116&click=0 "
        header = {
            "user-agent": "Mozilla/5.0 (Windows NT 10.0; WOW64)"
            "AppleWebKit/537.36 (KHTML, like Gecko) "
                          "Chrome/75.0.3770.100 Safari/537.36 "}
        response = requests.request(method="Get", url=url, headers=header)
        result = response.text
        return result
    except TimeoutError as e:
        return None


def parsing():
    result = get_web_content()
    if result is not None:
        html = etree.HTML(result)
        # 先獲取一個(gè)大的節(jié)點(diǎn),包含了想要獲取的所有信息
        ii = html.xpath('//*[@id="J_goodsList"]/ul/li')
       
        for _ in ii:
        # 采用循環(huán),依次從大節(jié)點(diǎn)中獲取小的節(jié)點(diǎn)內(nèi)容
            # ''.join() 將列表中的內(nèi)容拼接成一個(gè)字符串
            infoResult = {
            	# @href 表示:獲取屬性為href的內(nèi)容
                'href': "https:" + _.xpath('./div/div[1]/a/@href')[0],
                'title': ''.join(
                        _.xpath('./div/div[2]/div/ul/li/a/@title')),
                # text()表示獲取節(jié)點(diǎn)i里面的文本信息
                'price': _.xpath('./div/div[3]/strong/i/text()')[0],
                'info': ''.join(
                        _.xpath('./div/div[4]/a/em/text()')).strip(),
                'province': _.xpath('./div/div[9]/@data-province')[0]}
            print(infoResult)
    else:
        raise Exception("Failed to get page information, please check!")
    
    return None


if __name__ == '__main__':
    parsing()

結(jié)果圖片:

在這里插入圖片描述

到此這篇關(guān)于python使用xpath獲取頁(yè)面元素的使用的文章就介紹到這了,更多相關(guān)python xpath獲取頁(yè)面元素內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python中格式化字符串輸出的4種方式小結(jié)

    Python中格式化字符串輸出的4種方式小結(jié)

    本文主要介紹了Python中格式化字符串輸出的4種方式小結(jié),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • python字典的值可以修改嗎

    python字典的值可以修改嗎

    在本篇文章里小編給大家分享的是一篇關(guān)于python字典的值修改的方法步驟,需要的朋友們可以學(xué)習(xí)下。
    2020-06-06
  • python 從文件夾抽取圖片另存的方法

    python 從文件夾抽取圖片另存的方法

    今天小編就為大家分享一篇python 從文件夾抽取圖片另存的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-12-12
  • 詳解python文件的操作和異常的處理

    詳解python文件的操作和異常的處理

    這篇文章主要為大家介紹了python文件的操作和異常的處理,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2021-12-12
  • Python3標(biāo)準(zhǔn)庫(kù)總結(jié)

    Python3標(biāo)準(zhǔn)庫(kù)總結(jié)

    在本篇內(nèi)容中我們給大家總結(jié)了關(guān)于Python3標(biāo)準(zhǔn)庫(kù)的相關(guān)內(nèi)容,需要的朋友們跟著學(xué)習(xí)下。
    2019-02-02
  • Python實(shí)現(xiàn)兩種多分類(lèi)混淆矩陣

    Python實(shí)現(xiàn)兩種多分類(lèi)混淆矩陣

    這篇文章主要為大家介紹了Python實(shí)現(xiàn)兩種多分類(lèi)混淆矩陣,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • 用Python爬取某乎手機(jī)APP數(shù)據(jù)

    用Python爬取某乎手機(jī)APP數(shù)據(jù)

    最近爬取的數(shù)據(jù)都是網(wǎng)頁(yè)端,今天來(lái)教大家如何爬取手機(jī)端app數(shù)據(jù)(本文以ios蘋(píng)果手機(jī)為例,其實(shí)安卓跟ios差不多)! 本文將以『某乎』為實(shí)戰(zhàn)案例,手把手教你從配置到代碼一步一步的爬取App數(shù)據(jù),需要的朋友可以參考下
    2021-06-06
  • Python基礎(chǔ)學(xué)習(xí)之條件控制語(yǔ)句小結(jié)

    Python基礎(chǔ)學(xué)習(xí)之條件控制語(yǔ)句小結(jié)

    如果我需要設(shè)置一個(gè)死循環(huán),然后靠條件來(lái)終止,怎么辦?一個(gè)很簡(jiǎn)單的問(wèn)題,但是我卻沒(méi)有說(shuō),這一篇本應(yīng)該在分支控制語(yǔ)句里面的,現(xiàn)在只能拿出來(lái)水文再寫(xiě)一篇了,需要的朋友可以參考下
    2021-05-05
  • python正確讀取文件路徑的三種方式

    python正確讀取文件路徑的三種方式

    這篇文章主要介紹了python正確讀取文件路徑的三種方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • Python通過(guò)yagmail實(shí)現(xiàn)發(fā)送郵件代碼解析

    Python通過(guò)yagmail實(shí)現(xiàn)發(fā)送郵件代碼解析

    這篇文章主要介紹了Python通過(guò)yagmail實(shí)現(xiàn)發(fā)送郵件代碼解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-10-10

最新評(píng)論