得到如下信息: “5.1 HV:/ 守門員戴手套沒法系鞋帶這種體育精神,值得尊敬%遇見足球 %足球 %精彩進(jìn)球 %意甲 %唯有足球不 https://v.douyin.com/eDFd28P/ 復(fù)制此鏈接,打開Dou音搜索,直接觀看視頻!”
通過正則取到信息中的地址:
share_url='5.1 HV:/ 守門員戴手套沒法系鞋帶這種體育精神,值得尊敬%遇見足球 %足球 %精彩進(jìn)球 %意甲 %唯有足球不 https://v.douyin.com/eDFd28P/ 復(fù)制此鏈接,打開Dou音搜索,直接觀看視頻!' short_url = re.findall('(https?://[^\s]+)', share_url)[0]
通過訪問得到的短連接,請求的地址會(huì)變成下面的
然后分析返回的數(shù)據(jù):
對返回的數(shù)據(jù)逐個(gè)篩選,發(fā)現(xiàn)這個(gè)連接可以直接訪問到視頻
對請求的地址重新整理獲取源視頻的地址:
headers = { "user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4430.93 Safari/537.36", } # 通過分享連接獲取跳轉(zhuǎn)的地址 url = requests.get(url=short_url,headers=headers).url # 通過跳轉(zhuǎn)的地址找到item_id item_id = re.findall('https://www.iesdouyin.com/share/video/(\d+)',url)[0] # 請求地址獲取數(shù)據(jù) rel_url = requests.get(url="https://www.iesdouyin.com/web/api/v2/aweme/iteminfo/?item_ids="+item_id,headers=headers).text # 篩出視頻地址 video_rul = json.loads(rel_url)['item_list'][0]['video']['play_addr']['url_list'][0]
以上步驟中可以得到視頻的地址:https://aweme.snssdk.com/aweme/v1/playwm/?video_id=v0300fg10000c29ouk4guk3mmkooa0r0ratio=720pline=0
將其中的playwm
替換為play
就可以得到?jīng)]有水印的地址
video_rul = json.loads(rel_url)['item_list'][0]['video']['play_addr']['url_list'][0].replace('/playwm/', '/play/')
import requests import re import json down_load_path = 'E:\下載的MP4\\' class D_y(): headers = { "user-agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4430.93 Safari/537.36", } def __init__(self,share_url): self.share_url = share_url def get_rel_url(self): # short_url = re.findall('(https?://[^\s]+)', self.share_url)[0] short_url = re.findall('(http[|s]?://[^\s]*/)', self.share_url)[0] url = requests.get(url=short_url, headers=self.headers).url # item_id = re.findall('https://www.iesdouyin.com/share/video/(\d+)', url)[0] item_id = url.split('/')[5] rel_url = requests.get(url="https://www.iesdouyin.com/web/api/v2/aweme/iteminfo/?item_ids=" + item_id,headers=self.headers).text video_rul = json.loads(rel_url)['item_list'][0]['video']['play_addr']['url_list'][0].replace('/playwm/','/play/') video = requests.get(url=video_rul,headers=self.headers).content video_name = json.loads(rel_url)['item_list'][0]['share_info']['share_title'].split('#')[0].split('@')[0].replace(' ','') with open(down_load_path+str(video_name)+'.mp4','wb') as f: f.write(video) f.close() print("【抖音短視頻】: {}.mp4 無水印視頻下載完成!".format(video_name)) if __name__ == '__main__': a = input("url:") D_y(a).get_rel_url()
大功告成?。?!
到此這篇關(guān)于教你用Python下載抖音無水印視頻的文章就介紹到這了,更多相關(guān)Python下載抖音視頻內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
標(biāo)簽:鷹潭 黔西 益陽 惠州 常德 上海 黑龍江 四川
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《教你用Python下載抖音無水印視頻》,本文關(guān)鍵詞 教,你用,Python,下載,抖音,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。