阅读文本大概需要 15 分钟。

1

目 标 场 景

相信大家平时刷抖音短视频的时候,看到颜值高的小姐姐,都有随手点赞关注的习惯。

如果一条条去刷确实很耗时间,如果 Python 能帮忙筛选出颜值高的小姐姐那就省了很多事。

本篇文章是借助「百度人脸识别」API,帮我们识别出抖音上颜值高的小姐姐,然后下载到手机相册中。

2

准 备 工 作

首先,项目需要对页面元素进行一些精准的操作,需要提前准备一部 Android 设备,激活开发者选项,并在开发者选项中打开 「USB 调试和指针位置」两处设置。

为了确保 adb 命令能正常使用,需要提前配置好 adb 开发环境。

页面元素中的部分元素没法利用 name 等常用属性获取到,可能需要获取到完整的「UI 树」,再利用 Airtest 判断是否存在某个 UI 元素。

另外,项目中会对视频进行人脸识别,获取到出现的所有人脸,再进行性别识别及颜值判断。

这里需要进行百度云后台,注册一个人脸识别的应用,获取到一组 「API Key 和 Secret Key」值。

然后利用官网提供的 API 文档即可获取到「access token」,由于 ak 的有效期为一个月,所以只需要初始化一次,后面就可以利用人脸识别接口进行正常的识别了。

appid = '你注册应用的appid'
api_key = '你注册应用的ak'
secret_key = '你注册应用的sk'def get_access_token():"""其关access_token有效期一般有一个月"""# 此变量赋值成自己API Key的值client_id = api_key  # 此变量赋值成自己Secret Key的值client_secret = secret_key  auth_url = 'https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials&client_id=' + client_id + '&client_secret=' + client_secretheader_dict = {'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; Trident/7.0; rv:11.0) like Gecko',"Content-Type": "application/json"}# 请求获取到token的接口response_at = requests.get(auth_url, headers=header_dict)json_result = json.loads(response_at.text)access_token = json_result['access_token']return access_token

3

编  写  脚  本

在上面已经配置好了 adb 环境的情况下,可以直接借助 python 中的 os 模块执行 adb 命令打开抖音 App。

# 抖音App的应用包名和初始Activity
package_name = 'com.ss.android.ugc.aweme'
activity_name = 'com.ss.android.ugc.aweme.splash.SplashActivity'def start_my_app(package_name, activity_name):"""打开应用adb shell am start -n com.tencent.mm/.ui.LauncherUI:param package_name::return:"""os.popen('adb shell am start -n %s/%s' % (package_name, activity_name))

接着,我们需要截取当前播放视频的截图到本地。

需要注意的是,抖音视频播放界面包含视频创作者头像、BGM 创作者头像等一些杂乱的元素,可能对人脸识别的结果产生一些误差,所以需要对屏幕截图之后的图像进行「二次裁剪」处理。

def get_screen_shot_part_img(image_name):"""获取手机截图的部分内容:return:"""# 截图os.system("adb shell /system/bin/screencap -p /sdcard/screenshot.jpg")os.system("adb pull /sdcard/screenshot.jpg %s" % image_name)# 打开图片img = Image.open(image_name).convert('RGB')# 图片的原宽、高(1080*2160)w, h = img.size# 截取部分,去掉其头像、其他内容杂乱元素img = img.crop((0, 0, 900, 1500))img.thumbnail((int(w / 1.5), int(h / 1.5)))# 保存到本地img.save(image_name)return image_name

现在可以使用百度提供的 API 获取到上面截图的人脸列表。

def parse_face_pic(pic_url, pic_type, access_token):"""人脸识别5秒之内:param pic_url::param pic_type::param access_token::return:"""url_fi = 'https://aip.baidubce.com/rest/2.0/face/v3/detect?access_token=' + access_token# 调用identify_faces,获取人脸列表json_faces = identify_faces(pic_url, pic_type, url_fi)if not json_faces:print('未识别到人脸')return Noneelse:# 返回所有的人脸return json_faces

从上述的人脸列表中筛选出性别为女,年龄为 18-30 岁之间,颜值超过 70 的小姐姐。

def analysis_face(face_list):"""分析人脸,判断颜值是否达标18-30之间,女,颜值大于80:param face_list:识别的脸的列表:return:"""# 是否能找到高颜值的美女find_belle = Falseif face_list:print('一共识别到%d张人脸,下面开始识别是否有美女~' % len(face_list))for face in face_list:# 判断是男、女if face['gender']['type'] == 'female':age = face['age']beauty = face['beauty']if 18 <= age <= 30 and beauty >= 70:print('颜值为:%d,及格,满足条件!' % beauty)find_belle = Truebreakelse:print('颜值为:%d,不及格,继续~' % beauty)continueelse:print('性别为男,继续~')continueelse:print('图片中没有发现人脸.')return find_belle

由于视频是连续播放的,很难通过截取视频某一帧,判断视频有出现颜值高的小姐姐。

另外,大部分短视频播放时长为「10s+」,这里需要对每一个视频多次截图去做人脸识别,直到识别到颜值高的小姐姐。

# 一条视频最长的识别时间
RECOGNITE_TOTAL_TIME = 10
# 识别次数
recognite_count = 1# 对当前视频截图去人脸识别
while True:# 获取截图print('开始第%d次截图' % recognite_count)# 截取屏幕有用的区域,过滤视频作者的头像、BGM作者的头像screen_name = get_screen_shot_part_img('images/temp%d.jpg' % recognite_count)# 人脸识别recognite_result = analysis_face(parse_face_pic(screen_name, TYPE_IMAGE_LOCAL, access_token))recognite_count += 1# 第n次识别结束后的时间recognite_time_end = datetime.now()# 这一条视频出现了颜值高的小姐姐if recognite_result:passelse:print('超时!!!这是一条没有吸引力的视频!')# 跳出里层循环break

一旦当前播放的视频识别出有颜值高的小姐姐,就需要模拟保存视频到本地的操作。

获取「分享」和「保存本地」两个按钮的坐标位置,依次利用 adb 执行点击操作即可下载视频到本地。

def save_video_met():""":return:"""# 分享os.system("adb shell input tap 1000 1500")time.sleep(0.05)# 保存到本地os.system("adb shell input tap 350 1700")

另外,由于下载视频的过程是一个耗时操作,在下载进度对话框还未消失之前,需要做一个「模拟等待」的操作。

def wait_for_download_finished(poco):"""从点击下载,到下载完全:return:"""element = Element()while True:# 由于是对话框,不能利用Element类来判断是否存在某个元素来准确处理# element_result = element.findElementByName('正在保存到本地')# 当前页面UI树元素信息# 注意:保存的时候可能会获取元素异常,这里需要抛出,并终止循环# com.netease.open.libpoco.sdk.exceptions.NodeHasBeenRemovedException: Node was no longer alive when query attribute "visible". Please re-select.try:ui_tree_content = json.dumps(poco.agent.hierarchy.dump(), indent=4).encode('utf-8').decode('unicode_escape')except Exception as e:print(e)print('异常,按下载处理~')breakif '正在保存到本地' in ui_tree_content:print('还在下载中~')time.sleep(0.5)continueelse:print('下载完成~')break

在视频保存到本地之后,就可以模拟向上滑动的操作,跳到播放「下一条视频」。

循环上面的操作,即可筛选出所有颜值高的小姐姐,并保存到本地。

def play_next_video():"""下一个视频从下往上滑动:return:"""os.system("adb shell input swipe 540 1300 540 500 100")

在脚本一条条刷视频的过程中,可能会遇到一下广告,我们需要对这类视频进行过滤。

def is_a_ad():"""判断的当前页面上是否是一条广告:return:"""element = Element()ad_tips = ['去玩一下', '去体验', '立即下载']find_result = Falsefor ad_tip in ad_tips:try:element_result = element.findElementByName(ad_tip)# 是一条广告,直接跳出find_result = Truebreakexcept Exception as e:find_result = Falsereturn find_result

4

结 果 结 论

运行上面的脚本,会自动打开抖音,对每一条小视频多次进行人脸识别,直到识别到颜值高的小姐姐,保存视频到本地,然后继续刷下一条短视频。

源码在阅读原文里,有女朋的同学可要小心尝试哦!

骚操作!用Python自动下载抖音小姐姐相关推荐

  1. 用 Python 全自动下载抖音小姐姐视频(附源码)

    作者:法纳斯特 为什么写这篇文章,主要也是因为看了一篇文章. 「用Python在抖音扒了这些高颜值女神后,突然成了人生赢家」,文中简述了一名工程师利用Python+ADB+鹅厂的AI,一晚上关注了一千 ...

  2. 用 Python 全自动下载抖音小姐姐视频

    (给Python开发者加星标,提升Python技能) 作者:法纳斯特(本文来自作者投稿,简介见末尾) 为什么写这篇文章,主要也是因为看了一篇文章. 「用Python在抖音扒了这些高颜值女神后,突然成了 ...

  3. 骚操作!用Python自动下载抖音美丽小姐姐(有对象的同学小心尝试!)

    阅读文本大概需要 15 分钟. 1 目 标 场 景 相信大家平时刷抖音短视频的时候,看到颜值高的小姐姐,都有随手点赞关注的习惯. 如果一条条去刷确实很耗时间,如果 Python 能帮忙筛选出颜值高的小 ...

  4. python可以自动录凭证_我用 Python 实现自动刷抖音小姐姐

    具体实现代码 # 图片压缩比例 SIZE_normal = 1.0 SIZE_small = 1.5 SIZE_more_small = 2.0 # adb手机截图 def get_screen_sh ...

  5. python3 爬虫实战:mitmproxy 对接 python 下载抖音小视频

    From:https://blog.csdn.net/Fan_shui/article/details/81461253 一.前言 前面我们已经用 appium 爬取了微信朋友圈,今天我们学习下 mi ...

  6. python爬取无水印抖音小姐姐视频(2018最新,含Pyqt客户端)

    各位小伙伴,之前一段时间迷上了抖音小姐姐视频,但是下载的视频都有水印,于是自己用Python 写了个爬取小姐姐视频的工具,大家可以直接拷贝到自己编译器上运行.此外,我还利用pyqt5写了个操作界面,这 ...

  7. python好用 appium fiddler_python3 爬虫实战:mitmproxy 对接 python 下载抖音小视频

    一.前言 前面我们已经用 appium 爬取了微信朋友圈,今天我们学习下 mitmproxy,mitmproxy 是干什么的呢,它跟 charles 和 fiddler类似,是一个抓包工具,以控制台的 ...

  8. Python批量下载 抖音无水印视频!

    导读: 本文 介绍了如何使用简单的Python爬虫爬取抖音上你喜欢的拍客的所有视频(包含 有水印和 无水印两种 ). 代码已上传至公众号后台,回复: 抖音 即可获得. 一.获取你喜欢的拍客的视频url ...

  9. python批量下载抖音无水印视频,附软件

    网上很多那种抖音视频解析,去水印下载的网站,不过都只可以下单个,下下来大多数标题还是乱码.一点都不geek. 咱们懒人找资源的粉丝最大的优点就是懒,这种重复性的活python帮咱们搞定. 批量下载抖音 ...

最新文章

  1. Spring-Security-入门(一):登录与退出
  2. 知识星球!!!!!!
  3. Linux中使用export命令设置环境变量
  4. 帮助你更好理解javascript中easing功能的网站 - Easings.net
  5. Java获取当前时间前几个月、季度
  6. linux系统相关硬件查询
  7. cpu核心数的线程数
  8. Akka并发编程——第六节:Actor模型(五)
  9. 信息安全系统设计基础第八周期中学习总结—20135227黄晓妍
  10. Layui 表格table自定义每一列的样式
  11. paip.python 调用qt ui 总结
  12. putty GB2312 BIG5 中文字符集补丁
  13. python制作密码字典_Python实现生成密码字典的方法示例
  14. 常见软件架构风格介绍
  15. 中英文字符的映射(TRANSLATE函数的运用)
  16. 【高项备考】多种类型计算题学习
  17. 基因家族特征分析 - 染色体定位分析
  18. 《关于TCP SYN包的超时与重传》——那些你应该知道的知识(四)
  19. jsPlumb 学习笔记
  20. P3084 照片 [差分约束]

热门文章

  1. 11 电路板设计protel DXP中新建工程和PCB图、把原理图和PCB图载入同一个工程和把元件导入PCB图的方法成都自动化开发
  2. java计算机毕业设计中小学生错题管理系统源程序+mysql+系统+lw文档+远程调试
  3. java计算机毕业设计车辆保险平台系统研究与设计MyBatis+系统+LW文档+源码+调试部署
  4. Docker容器修改hosts文件重启不变
  5. SRS音频技术介绍一
  6. [爆笑网文]伤害MM的六句金言
  7. Antd Tabs切换时状态遗留问题避坑
  8. 学期作品-考勤信息管理系统文档之《立项报告》
  9. linux 5识别网卡,redhat Linux 5.0 如何识别网卡和安装驱动
  10. 几种T卡座的检测方法