本文实例为大家分享了python批量爬取下载抖音视频的具体代码,供大家参考,具体内容如下
import os import requests import re import sys import asyncio import aiohttp headers = { 'user-agent': 'Mozilla/5.0 (iPhone; CPU iPhone OS 11_0 like Mac OS X) AppleWebKit/604.1.38 (KHTML, like Gecko) ' 'Version/11.0 Mobile/15A372 Safari/604.1' } VIDEO_URLS, PAGE = [], 1 def get_info(url): """ :param url: 用户的链接 :return:返回name,dytk,user_id 参数 """ name = None dytk = None user_id = None try: response = requests.get(url, headers=headers) user_id = response.url.split('/')[5].split('?')[0] name = re.search(r'class="nickname">(.*?)<', response.text)[1] dytk = re.search(r"dytk: '(.*?)'", response.text)[1] except (TypeError, IndexError): sys.stdout.write('Waring:输入的链接错误') except requests.exceptions: sys.stdout.write('Waring:链接错误') finally: return name, user_id, dytk def make_dir(name): """ 建立文件夹 :param name: 用户名称 :return: """ if not os.path.isdir(name): os.mkdir(name) else: pass def get_all_video(user_id, max_cursor, dytk): """ 获取视频的地址 :param user_id: :param max_cursor: :param dytk: :return: """ url = "https://www.amemv.com/aweme/v1/aweme/post/?" params = {'user_id': user_id, 'count': 21, 'max_cursor': max_cursor, 'dytk': dytk} try: response = requests.get(url=url, params=params, headers=headers) if response.status_code == 200: datas = response.json() for data in datas['aweme_list']: name = data.get('share_info').get('share_desc') url = data.get('video').get('play_addr').get('url_list')[0].replace('playwm', 'play') VIDEO_URLS.append([name, url]) if datas['has_more'] == 1 and datas.get('max_cursor') != 0: global PAGE print(f'收集第{PAGE}页视频') PAGE += 1 return get_all_video(user_id, datas.get('max_cursor'), dytk) else: print('收集完成') return VIDEO_URLS else: print('状态码:', response.status_code) return None except Exception as e: print('Waring:', e) return async def download_video(index, name, video_name, url): """ 下载视频 :param index: 视频id :param name: 用户名称 :param video_name: 视频名称 :param url: 下载url :return: """ print(f'正在下载第{index}个视频:{video_name}') video_path = '{}/{}.mp4'.format(name, video_name) if not os.path.isfile(video_path): try: async with aiohttp.ClientSession() as session: async with session.get(url=url, headers=headers, ssl=False) as response: with open(video_path, 'wb') as f: while True: chunk = await response.content.read(1024) f.write(chunk) if not chunk: break print(f'下载完成第{index}个视频:{video_name}') except Exception as e: print('waring:download faild', video_name, e) return else: print('文件已存在') def main(): url = 'http://v.douyin.com/dEorkn/' name, user_id, dytk = get_info(url) if not (name, user_id, dytk): return make_dir(name) get_all_video(user_id, 0, dytk) print(f'{name}:总共有{len(VIDEO_URLS)}个视频') tasks = [] for index, item in enumerate(VIDEO_URLS, 1): video_name = item[0] url = item[1] tasks.append(asyncio.ensure_future(download_video(index, name, video_name, url))) loop = asyncio.get_event_loop() loop.run_until_complete(asyncio.wait(tasks)) loop.run_until_complete(asyncio.sleep(0)) loop.close() print(f'{name}视频下载完成!') if __name__ == '__main__': main()
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍python批量下载抖音视频,包括了python批量下载抖音视频的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了python批量下载抖音视频的具体代码,供大家参考,具体内容如下 知识储备:博主是在Pycharm下进行的 文件夹:dou_ying 1、在文件夹doy_ying下新建第一个文件:dou_ying_video_download.py 代码: 温馨提示: 有些库
本文向大家介绍Python爬取qq music中的音乐url及批量下载,包括了Python爬取qq music中的音乐url及批量下载的使用技巧和注意事项,需要的朋友参考一下 前言 qq music上的音乐还是不少的,有些时候想要下载好听的音乐,但有每次在网页下载都是烦人的登录什么的。于是,来了个qqmusic的爬虫。至少我觉得for循环爬虫,最核心的应该就是找到待爬元素所在url吧。下面开始找吧
本文向大家介绍python3下载抖音视频的完整代码,包括了python3下载抖音视频的完整代码的使用技巧和注意事项,需要的朋友参考一下 python3下载抖音视频的代码如下所示: 总结 以上所述是小编给大家介绍的python3下载抖音视频的完整代码,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对呐喊教程网站的支持! 如果你觉得本文对你有帮助,欢迎转载,
本文向大家介绍python 批量下载bilibili视频的gui程序,包括了python 批量下载bilibili视频的gui程序的使用技巧和注意事项,需要的朋友参考一下 运行效果: 完整代码: 以上就是python 批量下载bilibili视频的gui程序的详细内容,更多关于python 批量下载bilibili视频的资料请关注呐喊教程其它相关文章!
通过该接口可以批量获取视频字幕下载地址,音频转写后可用,地址为: http://spark.bokecc.com/api/subtitle/videos 需要传递以下参数: 参数 说明 userid 用户 id,不可为空 videoids 视频 id,以","分割,最多100个,不可为空 format 返回格式,xml 或 json 返回数据subtiles包括如下字段: 字段名 说明 subti
本文向大家介绍python动态网页批量爬取,包括了python动态网页批量爬取的使用技巧和注意事项,需要的朋友参考一下 四六级成绩查询网站我所知道的有两个:学信网(http://www.chsi.com.cn/cet/)和99宿舍(http://cet.99sushe.com/),这两个网站采用的都是动态网页。我使用的是学信网,好了,网站截图如下: 网站的代码