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

Python爬取某拍短視頻

 更新時間:2021年06月11日 10:20:14   作者:五包辣條!  
現(xiàn)在短視頻可謂是一騎絕塵,吃飯的時候、休息的時候、躺在床上都在刷短視頻,今天給大家?guī)韕ython爬蟲進階 :美拍視頻地址加密解析,需要的朋友可以參考下

一、抓取目標

目標網(wǎng)址:美拍視頻

在這里插入圖片描述

二、工具使用

開發(fā)環(huán)境:win10、python3.7
開發(fā)工具:pycharm、Chrome
工具包:requests、xpath、base64

三、重點學習內容

爬蟲采集數(shù)據(jù)的解析過程
js代碼調試技巧
js逆向解析代碼
Python代碼的轉換

四、項目思路解析

進入到網(wǎng)站的首頁
挑選你感興趣的分類
根據(jù)首頁地址獲取到進入詳情頁面的超鏈接的跳轉地址

在這里插入圖片描述

找到對應加密的視頻播放地址數(shù)據(jù)

在這里插入圖片描述

這個數(shù)據(jù)是靜態(tài)的網(wǎng)頁數(shù)據(jù),通過js代碼進行解碼的
找到對應的解析代碼
先找到視頻的播放地址
找到解析視頻地址的加密js文件
點擊播放的時候會觸發(fā)文件

在這里插入圖片描述

大致能看出來這個是base64加密之后的數(shù)據(jù)
在對應的js文件里搜索關鍵字
找到js的加密方式

在這里插入圖片描述

js函數(shù)的一些函數(shù)的用法

# eplace()方法用于在字符串中用一些字符替換另一些字符
    # parseInt 數(shù)據(jù)轉換成對應的整型
    # base64.atob   對base64編碼過的字符串進行解碼
    # substring 方法可在字符串中抽取從 start 下標開始的指定數(shù)目的字符

在這里插入圖片描述

將js代碼轉換成Python代碼

import base64

def decode(data):
    def getHex(a):
        return {
            'str': a[4:],
            'hex': ''.join(list(a[:4])[::-1]),
        }

    def getDec(a):
        b = str(int(a, 16))
        return {
            'pre': list(b[:2]),
            'tail': list(b[2:]),
        }

    def substr(a, b):
        c = a[0: int(b[0])]
        d = a[int(b[0]): int(b[0]) + int(b[1])]
        return c + a[int(b[0]):].replace(d, "")

    def getPos(a, b):
        b[0] = len(a) - int(b[0]) - int(b[1])
        return b

    b = getHex(data)
    c = getDec(b['hex'])
    d = substr(b['str'], c['pre'])
    return base64.b64decode(substr(d, getPos(d, c['tail'])))

print(decode("e121Ly9tBrI84RdnZpZGVvMTAubWVpdHVkYXRhLmNvbS82MGJjZDcwNTE3NGZieXBueG5udnRwMTA5N19IMjY0XzFfNWY3YThmM2U0MTEwNy5tc2JVjAu3EDQ="))

得出最終視頻播放地址

在這里插入圖片描述
在這里插入圖片描述

五、簡易源碼分享

import requests
from lxml import etree
import base64

def decode_mp4(data):
    def getHex(a):
        return {
            'str': a[4:],
            'hex': ''.join(list(a[:4])[::-1]),
        }

    def getDec(a):
        b = str(int(a, 16))
        return {
            'pre': list(b[:2]),
            'tail': list(b[2:]),
        }

    def substr(a, b):
        c = a[0: int(b[0])]
        d = a[int(b[0]): int(b[0]) + int(b[1])]
        return c + a[int(b[0]):].replace(d, "")

    def getPos(a, b):
        b[0] = len(a) - int(b[0]) - int(b[1])
        return b

    b = getHex(data)
    c = getDec(b['hex'])
    d = substr(b['str'], c['pre'])
    return base64.b64decode(substr(d, getPos(d, c['tail'])))
# 運行主函數(shù)
def main():
    url = 'https://www.meipai.com'
    headers = {
        'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.142 Safari/537.36',
    }
    response = requests.get(url=url, headers=headers)
    html_data = etree.HTML(response.text)
    href_list = html_data.xpath('//div/a/@href')
    # print(href_list)
    for href in href_list:
        res = requests.get('https://www.meipai.com' + href, headers=headers)
        html = etree.HTML(res.text)
        name = html.xpath('//div[@id="detailVideo"]/img/@alt')[0]
        mp4_data = html.xpath('//div[@id="detailVideo"]/@data-video')[0]
        # print(name, mp4_data)
        mp4_url = decode_mp4(mp4_data).decode('utf-8')
        print(mp4_url)
        result = requests.get("http:" + mp4_url)
        with open(name + ".mp4", 'wb') as f:
            f.write(result.content)
            f.close()


if __name__ == '__main__':
    main()

到此這篇關于Python爬取某拍短視頻的文章就介紹到這了,更多相關Python爬取視頻內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 一篇文章帶你學習python的函數(shù)與類

    一篇文章帶你學習python的函數(shù)與類

    這篇文章主要為大家介紹了python的函數(shù)與類,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-01-01
  • Python?OpenCV超詳細講解基本功能

    Python?OpenCV超詳細講解基本功能

    OpenCV用C++語言編寫,它具有C?++,Python,Java和MATLAB接口,并支持Windows,Linux,Android和Mac?OS,OpenCV主要傾向于實時視覺應用,并在可用時利用MMX和SSE指令,本篇文章帶你了解OpenCV的基本功能
    2022-04-04
  • python更新數(shù)據(jù)庫中某個字段的數(shù)據(jù)(方法詳解)

    python更新數(shù)據(jù)庫中某個字段的數(shù)據(jù)(方法詳解)

    這篇文章主要介紹了python更新數(shù)據(jù)庫中某個字段的數(shù)據(jù)方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • Python 列表(List)的底層實現(xiàn)原理分析

    Python 列表(List)的底層實現(xiàn)原理分析

    這篇文章主要介紹了Python 列表(List)的底層實現(xiàn)原理分析,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03
  • Python中關于面向對象私有屬性方法的詳細講解

    Python中關于面向對象私有屬性方法的詳細講解

    在實際開發(fā)中,對象的某些屬性或方法可能只希望在對象的內部被使用,而不希望在外部被訪問到,私有屬性就是對象不希望公開的屬性,私有方法就是對象不希望公開的方法
    2021-10-10
  • 解決python路徑錯誤,運行.py文件,找不到路徑的問題

    解決python路徑錯誤,運行.py文件,找不到路徑的問題

    這篇文章主要介紹了解決python路徑錯誤,運行.py文件,找不到路徑的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03
  • 如何在Python中進行異常處理

    如何在Python中進行異常處理

    這篇文章主要介紹了如何在Python中進行異常處理,Python中使用用異常對象(exception object)表示異常情況,當程序運行遇到錯誤后,就會觸發(fā)發(fā)異常,下文關于異常處理的相關內容,需要的小伙伴可以參考一下
    2022-03-03
  • 解決Python在導入文件時的FileNotFoundError問題

    解決Python在導入文件時的FileNotFoundError問題

    這篇文章主要介紹了解決Python在導入文件時的FileNotFoundError問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-04-04
  • 基于Python中的yield表達式介紹

    基于Python中的yield表達式介紹

    今天小編就為大家分享一篇基于Python中的yield表達式詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • Gradio機器學習模型快速部署工具應用分享前篇

    Gradio機器學習模型快速部署工具應用分享前篇

    這篇文章主要為大家介紹了Gradio機器學習模型快速部署工具應用分享前篇,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04

最新評論