一、获取抖音视频连接
得到如下信息: “5.1 hv:/ 守门员戴手套没法系鞋带这种体育精神,值得尊敬%遇见足球 %足球 %精彩进球 %意甲 %唯有足球不 https://v.douyin.com/edfd28p/ 复制此链接,打开dou音搜索,直接观看视频!”
通过正则取到信息中的地址:
1
2
|
share_url = '5.1 hv:/ 守门员戴手套没法系鞋带这种体育精神,值得尊敬%遇见足球 %足球 %精彩进球 %意甲 %唯有足球不 https://v.douyin.com/edfd28p/ 复制此链接,打开dou音搜索,直接观看视频!'
short_url = re.findall( '(https?://[^\s]+)' , share_url)[ 0 ]
|
二、访问地址对返回的数据进行分析
通过访问得到的短连接,请求的地址会变成下面的
然后分析返回的数据:
对返回的数据逐个筛选,发现这个连接可以直接访问到视频
对请求的地址重新整理获取源视频的地址:
1
2
3
4
5
6
7
8
9
10
11
12
|
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" ,
}
# 通过分享连接获取跳转的地址
url = requests.get(url = short_url,headers = headers).url
# 通过跳转的地址找到item_id
item_id = re.findall( 'https://www.iesdouyin.com/share/video/(\d+)' ,url)[ 0 ]
# 请求地址获取数据
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=v0300fg10000c29ouk4guk3mmkooa0r0&ratio=720p&line=0
将其中的playwm
替换为play
就可以得到没有水印的地址
1
|
video_rul = json.loads(rel_url)[ 'item_list' ][ 0 ][ 'video' ][ 'play_addr' ][ 'url_list' ][ 0 ].replace( '/playwm/' , '/play/' )
|
四、整合代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
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()
|
大功告成!!!
到此这篇关于教你用python下载抖音无水印视频的文章就介绍到这了,更多相关python下载抖音视频内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://blog.csdn.net/qq_33235529/article/details/116493525