#!/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 :[email protected]
'''
import re
import sys
import json
import Util
import getopt
import requests
from retrying import retry
def printUsage():
print('''
使用方法: 1、添加为环境变量 2、输入命令
-u<url 抖音复制的链接:https://v.douyin.com/JtcjTwo/>
-m<music 是否下载音频,默认为yes可选no>
-n<name 用于自定义视频文件名,默认不设置>
例如:TikTokDownload.exe -u https://v.douyin.com/JtcjTwo/ -m yes -n 下载1
''')
TikTokDownLoad.exe --url=<抖音复制的链接> --music=<是否下载音频,默认为yes可选no> --name=<用于自定义视频文件名,默认不设置>
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():
url = ""
music = "yes"
name = ""
try:
opts, args = getopt.getopt(sys.argv[1:], "h:u:m:n:", [
"url=", "music=", "name="])
except getopt.GetoptError:
printUsage()
sys.exit(-1)
try:
if opts == []:
printUsage()
url = str(input("请输入抖音链接:"))
return url, music, name
except:
pass
for opt, arg in opts:
if opt == '-h':
printUsage()
sys.exit(-1)
elif opt in ("-u", "--url"):
url = arg
elif opt in ("-m", "--music"):
music = arg
elif opt in ("-n", "--name"):
name = arg
return url, music, name
@retry(stop_max_attempt_number=3)
def download(video_url, music_url, video_title, music_title, headers, music, name):
# 视频下载
if video_url == '':
print('[ 提示 ]:该视频可能无法下载哦~\r')
return
else:
r = requests.get(url=video_url, headers=headers)
if not Util.Status_Code(r.status_code):
if video_title == '':
video_title = '[ 提示 ]:此视频没有文案_%s\r' % music_title
video_title = Util.replaceT(video_title)
music_title = Util.replaceT(music_title)
if name == "":
name = video_title
with open(f'{name}.mp4', 'wb') as f:
f.write(r.content)
print('[ 视频 ]:%s.mp4 下载完成\r' % name)
if music_url == '':
print('[ 提示 ]:下载出错\r')
# return
else:
# 原声下载
if music != '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.mp3 下载完成\r' % music_title)
# return
def video_download(url, music, name, headers):
r = requests.get(url=Find(url)[0])
key = re.findall('video/(\d+)?', str(r.url))[0]
# 官方接口
# 旧接口22/12/23失效
# jx_url = f'https://www.iesdouyin.com/web/api/v2/aweme/iteminfo/?item_ids={self.aweme_id[i]}'
# 23/01/11
# 此ies domian暂时不需要xg参数
# 单作品接口 'aweme_detail'
# 主页作品 'aweme_list'
jx_url = Util.Urls().POST_DETAIL + Util.XBogus(
f'aweme_id={key}&aid=1128&version_name=23.5.0&device_platform=android&os_version=2333').params
js = Util.json.loads(Util.requests.get(
url=jx_url, headers=headers).text)
if js == '':
input('[ 提示 ]:获取视频数据失败,请从web端获取新ttwid填入配置文件填入配置文件\r')
exit()
try:
video_url = str(js['aweme_detail']['video']['play_addr']
['url_list'][2]) # .replace('playwm', 'play') # 去水印后链接
except:
print('[ 提示 ]:视频链接获取失败\r')
video_url = ''
try:
music_url = str(js['aweme_detail']['music']['play_url']['url_list'][0])
except:
print('[ 提示 ]:该音频目前不可用\r')
music_url = ''
try:
video_title = str(js['aweme_detail']['desc'])
music_title = str(js['aweme_detail']['music']['author']) + '创作的视频原声'
except:
print('[ 提示 ]:标题获取失败\r')
video_title = '视频走丢啦~'
music_title = '音频走丢啦~'
download(video_url, music_url, video_title,
music_title, headers, music, name)
if name == "main":
url, music, name = main()
# 获取命令行参数
cmd = Util.Command()
# 获取headers
headers = Util.Cookies(cmd.setting()).dyheaders
video_download(url, music, name, headers)
input('[ 提示 ]:按任意键退出')
sys.exit()