濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > python使用xpath獲取頁(yè)面元素的使用

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

熱門標(biāo)簽:哈爾濱外呼系統(tǒng)代理商 徐州天音防封電銷卡 佛山防封外呼系統(tǒng)收費(fèi) 不錯(cuò)的400電話辦理 獲客智能電銷機(jī)器人 南昌辦理400電話怎么安裝 鄭州智能外呼系統(tǒng)運(yùn)營(yíng)商 湛江電銷防封卡 電話機(jī)器人適用業(yè)務(wù)

關(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%88wq=%E6%97%A0%E"
  "9%92%A2%E5%9C%88ev=1_68131%5Epvid=afbf41410b164c1b91d"
        "abdf18ae8ab5cpage=5s=116click=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)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • python數(shù)據(jù)XPath使用案例詳解
  • python網(wǎng)絡(luò)爬蟲精解之XPath的使用說(shuō)明
  • python動(dòng)態(tài)網(wǎng)站爬蟲實(shí)戰(zhàn)(requests+xpath+demjson+redis)
  • Python爬蟲必備之XPath解析庫(kù)
  • Python爬蟲之用Xpath獲取關(guān)鍵標(biāo)簽實(shí)現(xiàn)自動(dòng)評(píng)論蓋樓抽獎(jiǎng)(二)
  • python數(shù)據(jù)解析之XPath詳解

標(biāo)簽:紹興 懷化 蘭州 蕪湖 呂梁 廣西 吉安 安康

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《python使用xpath獲取頁(yè)面元素的使用》,本文關(guān)鍵詞  python,使用,xpath,獲取,頁(yè)面,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《python使用xpath獲取頁(yè)面元素的使用》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于python使用xpath獲取頁(yè)面元素的使用的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    房山区| 瓮安县| 临邑县| 兴业县| 疏附县| 本溪市| 于田县| 大竹县| 牡丹江市| 高碑店市| 惠州市| 进贤县| 鲁甸县| 长垣县| 棋牌| 湖口县| 民乐县| 横峰县| 慈利县| 塘沽区| 乌拉特前旗| 易门县| 锦屏县| 富平县| 崇信县| 理塘县| 贵定县| 上蔡县| 东阳市| 缙云县| 富蕴县| 松溪县| 凌海市| 吐鲁番市| 宣恩县| 偏关县| 宜川县| 凤台县| 桐梓县| 兴业县| 绥宁县|