forked from Johnserf-Seed/TikTokDownload
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathTikTokDownload.py
114 lines (104 loc) · 4.08 KB
/
TikTokDownload.py
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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
#!/usr/bin/env python
# -*- encoding: utf-8 -*-
'''
@Description:懒得优化这一块
@Date :2020/12/28 13:14:29
@Author :JohnserfSeed
@version :1.0
@License :(C)Copyright 2017-2020, Liugroup-NLPR-CASIA
@Mail :johnserfseed@gmail.com
'''
import requests,re,json,sys,getopt
from retrying import retry
def printUsage():
print ('''
使用方法: 1、添加为环境变量 2、输入命令
-u<url 抖音复制的链接:https://v.douyin.com/JtcjTwo/>
-m<music 是否下载音频,默认为yes可选no>
例如:TikTokDownload.exe -u https://v.douyin.com/JtcjTwo/ -m yes
''')
#TikTokDownLoad.exe --url=<抖音复制的链接> --music=<是否下载音频,默认为yes可选no>
def Find(string):
# findall() 查找匹配正则表达式的字符串
url = re.findall('http[s]?://(?:[a-zA-Z]|[0-9]|[$-_@.&+]|[!*\(\),]|(?:%[0-9a-fA-F][0-9a-fA-F]))+', string)
return url
def main():
urlarg=""
musicarg="yes"
try:
opts, args = getopt.getopt(sys.argv[1:],"hu:m:",["url=","music="])
except getopt.GetoptError:
printUsage()
sys.exit(-1)
try:
if opts == []:
printUsage()
urlarg = str(input("请输入抖音链接:"))
return urlarg,musicarg
except:
pass
for opt,arg in opts:
if opt == '-h':
printUsage()
sys.exit(-1)
elif opt in ("-u", "--url"):
urlarg=arg
elif opt in ("-m","--music"):
musicarg=arg
return urlarg,musicarg
@retry(stop_max_attempt_number=3)
def download(video_url,music_url,video_title,music_title,headers,musicarg):
#视频下载
if video_url == '':
print('[ 提示 ]:该视频可能无法下载哦~\r')
return
else:
r=requests.get(url=video_url,headers=headers)
if video_title == '':
video_title = '[ 提示 ]:此视频没有文案_%s\r' % music_title
with open(f'{video_title}.mp4','wb') as f:
f.write(r.content)
print('[ 视频 ]:%s下载完成\r' % video_title)
if music_url == '':
print('[ 提示 ]:下载出错\r')
#return
else:
#原声下载
if musicarg != 'yes':
print('[ 提示 ]:不下载%s视频原声\r' % video_title)
#return
else:
r=requests.get(url=music_url,headers=headers)
with open(f'{music_title}.mp3','wb') as f:
f.write(r.content)
print('[ 音频 ]:%s下载完成\r' % music_title)
#return
def video_download(urlarg,musicarg):
headers = {
'user-agent': 'Mozilla/5.0 (Linux; Android 8.0; Pixel 2 Build/OPD3.170816.012) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/87.0.4280.88 Mobile Safari/537.36 Edg/87.0.664.66'
}
r = requests.get(url = Find(urlarg)[0])
key = re.findall('video/(\d+)?',str(r.url))[0]
jx_url = f'https://www.iesdouyin.com/web/api/v2/aweme/iteminfo/?item_ids={key}' #官方接口
js = json.loads(requests.get(url = jx_url,headers=headers).text)
try:
video_url = str(js['item_list'][0]['video']['play_addr']['url_list'][0]).replace('playwm','play') #去水印后链接
except:
print('[ 提示 ]:视频链接获取失败\r')
video_url = ''
try:
music_url = str(js['item_list'][0]['music']['play_url']['url_list'][0])
except:
print('[ 提示 ]:该音频目前不可用\r')
music_url = ''
try:
video_title = str(js['item_list'][0]['desc'])
music_title = str(js['item_list'][0]['music']['author'])
except:
print('[ 提示 ]:标题获取失败\r')
video_title = '视频走丢啦~'
music_title = '音频走丢啦~'
download(video_url,music_url,video_title,music_title,headers,musicarg)
if __name__=="__main__":
urlarg,musicarg = main()
video_download(urlarg,musicarg)