python利用Appium实现自动控制移动设备并提取数据功能
以控制抖音app滑动并获取抖音短视频发布者昵称和点赞数等信息为例:
1. 安装appium-python-client模块并启动已安装好的环境 1.1 安装appium-python-client模块在window的虚拟环境下执行pip install appium-python-client
1.2 启动夜神模拟器进入夜神模拟器所在的安装路径的bin目录下,进入cmd终端,使用adb命令建立adb server和模拟器的连接
1.adb devices
C:Program Files (x86)Noxbin>adb devicesList of devices attached* daemon not running; starting now at tcp:5037* daemon started successfully
2.nox_adb.exe connect 127.0.0.1:62001
C:Program Files (x86)Noxbin>nox_adb.exe connect 127.0.0.1:62001already connected to 127.0.0.1:62001
3.adb devices
C:Program Files (x86)Noxbin>adb devicesList of devices attached127.0.0.1:62001 device1.3 启动appium-desktop
点击start server启动appium服务
[Appium] Welcome to Appium v1.10.0[Appium] Appium REST http interface listener started on 0.0.0.0:47231.4 利用上一小节所学习的内容获取Desired Capabilities参数
1.获取模拟设备的型号
打开设置——关于平板电脑 查看型号,获取模拟设备的型号2.获取app包名称 以及 app进程名
打开模拟器中的抖音短视频app 在adb连接正确的情况下,在夜神模拟器安装目录的bin目录下的cmd中输入adb shell 进入adb shell后输入 dumpsys activity | grep mFocusedActivity ``com.ss.android.ugc.aweme`就是app包名 .main.MainActivity就是进程名 注意前边有个点.2. 初始化以及获取移动设备分辨率完成代码如下,并运行代码查看效果:如果模拟器中抖音app被启动,并打印出模拟设备的分辨率则成功
from appium import webdriver# 初始化配置,设置Desired Capabilities参数desired_caps = { ’platformName’: ’Android’, ’deviceName’: ’SM-G955F’, ’appPackage’: ’com.ss.android.ugc.aweme’, ’appActivity’: ’.main.MainActivity’}# 指定Appium Serverserver = ’http://localhost:4723/wd/hub’# 新建一个driverdriver = webdriver.Remote(server, desired_caps)# 获取模拟器/手机的分辨率(px)width = driver.get_window_size()[’width’]height = driver.get_window_size()[’height’]print(width, height)
移动设备分辨率
driver.get_window_size()[‘width’] driver.get_window_size()[‘height’]3. 定位元素以及提取文本的方法3.1 点击appium desktop右上角的放大镜图标如图填写配置,并点击start session
3.2 定位界面的使用方法如下图所示3.3 点击短视频的作者名字,查看并获取该元素的id3.4 在python使用代码通过元素id获取该元素的文本内容实例化appium driver对象后添加如下代码,运行并查看效果
# 获取视频的各种信息:使用appium desktop定位元素print(driver.find_element_by_id(’bc’).text) # 发布者名字print(driver.find_element_by_id(’al9’).text) # 点赞数print(driver.find_element_by_id(’al_’).text) # 留言数print(driver.find_element_by_id(’a23’).text) # 视频名字,可能不存在,报错
定位元素及获取其文本内容的方法
driver.find_element_by_id(元素的id).text driver.find_element_by_xpath(定位元素的xpath规则).text4. 控制抖音app滑动4.1 appium滑动的函数从(start_x, start_y)滑动到(end_x, end_y)
driver.swipe(start_x, start_y, end_x, end_y) 4.2 控制抖音app滑动的代码实现
start_x = width // 2 # 滑动的起始点的x坐标,屏幕宽度中心点start_y = height // 3 * 2 # 滑动的起始点的y坐标,屏幕高度从上开始到下三分之二处distance = height // 2 # y轴滑动距离:屏幕高度一半的距离end_x = start_x # 滑动的终点的x坐标end_y = start_y-distance # 滑动的终点的y坐标# 滑动driver.swipe(start_x, start_y, end_x, end_y)5. 整理并完成自动滑动的代码
import timefrom appium import webdriverclass DouyinAction(): '''自动滑动,并获取抖音短视频发布者的id''' def __init__(self, nums:int=None):# 初始化配置,设置Desired Capabilities参数self.desired_caps = { ’platformName’: ’Android’, ’deviceName’: ’SM-G955F’, ’appPackage’: ’com.ss.android.ugc.aweme’, ’appActivity’: ’.main.MainActivity’}# 指定Appium Serverself.server = ’http://localhost:4723/wd/hub’# 新建一个driverself.driver = webdriver.Remote(self.server, self.desired_caps)# 获取模拟器/手机的分辨率(px)width = self.driver.get_window_size()[’width’]height = self.driver.get_window_size()[’height’]print(width, height)# 设置滑动初始坐标和滑动距离self.start_x = width//2 # 屏幕宽度中心点self.start_y = height//3*2 # 屏幕高度从上开始到下三分之二处self.distance = height//2 # 滑动距离:屏幕高度一半的距离# 设置滑动次数self.nums = nums def comments(self):# app开启之后点击一次屏幕,确保页面的展示time.sleep(2)self.driver.tap([(500, 1200)], 500) def scroll(self):# 无限滑动i = 0while True: # 模拟滑动 print(’滑动ing...’) self.driver.swipe(self.start_x, self.start_y, self.start_x, self.start_y-self.distance) time.sleep(1) self.get_infos() # 获取视频发布者的名字 # 设置延时等待 time.sleep(4) # 判断是否退出 if self.nums is not None and self.nums == i:break i += 1 def get_infos(self):# 获取视频的各种信息:使用appium desktop定位元素print(self.driver.find_element_by_id(’bc’).text) # 发布者名字print(self.driver.find_element_by_id(’al9’).text) # 点赞数print(self.driver.find_element_by_id(’al_’).text) # 留言数print(self.driver.find_element_by_id(’a23’).text) # 视频名字,可能不存在,报错# # 点击【分享】坐标位置 671,1058# self.driver.tap([(671, 1058)])# time.sleep(2)# # 向左滑动露出 【复制链接】 580,1100 --> 200, 1100# self.driver.swipe(580,1100, 20, 200, 1100)# # self.driver.get_screenshot_as_file(’./a.png’) # 截图# # 点击【复制链接】 距离右边60 距离底边170 720-60,1280-170# self.driver.tap([(660, 1110)])# # self.driver.get_screenshot_as_file(’./b.png’) # 截图 def main(self):self.comments() # 点击一次屏幕,确保页面的展示time.sleep(2)self.scroll() # 滑动if __name__ == ’__main__’: action = DouyinAction(nums=5) action.main()
至此,可以参考爬虫5.0课程项目库,使用fiddler等抓包工具,利用appium+mitmproxy+wget等python模块自动获取抖音视频文件
6. 关于模拟式移动端爬虫的参考阅读https://github.com/butomo1989/docker-android
https://blog.csdn.net/weixin_42620645/article/details/83828863
https://blog.csdn.net/weixin_39211232/article/details/83410130#Android_16
https://www.jianshu.com/p/bf1ca3d4ac76
http://www.testclass.net/appium/
小结了解 appium-python-client模块定位元素以及提取其文本内容的方法了解 appium-python-client模块控制滑动动作的方法 7. 完整代码
douyin.py
import timefrom appium import webdriverclass DouyinAction(): '''自动滑动,并获取抖音短视频发布者的id''' def __init__(self, nums:int=None):# 初始化配置,设置Desired Capabilities参数self.desired_caps = { ’platformName’: ’Android’, ’deviceName’: ’SM-G955F’, ’appPackage’: ’com.ss.android.ugc.aweme’, ’appActivity’: ’.main.MainActivity’}# 指定Appium Serverself.server = ’http://localhost:4723/wd/hub’# 新建一个driverself.driver = webdriver.Remote(self.server, self.desired_caps)# 获取模拟器/手机的分辨率(px)width = self.driver.get_window_size()[’width’]height = self.driver.get_window_size()[’height’]print(width, height)# 设置滑动初始坐标和滑动距离self.start_x = width//2 # 屏幕宽度中心点self.start_y = height//3*2 # 屏幕高度从上开始到下三分之二处self.distance = height//2 # 滑动距离:屏幕高度一半的距离# 设置滑动次数self.nums = nums def comments(self):# app开启之后点击一次屏幕,确保页面的展示time.sleep(2)self.driver.tap([(500, 1200)], 500) def scroll(self): print(’滑动ing...’)self.driver.swipe(self.start_x, self.start_y, self.start_x, self.start_y-self.distance)time.sleep(3)self.driver.find_element_by_xpath(’/hierarchy/android.widget.FrameLayout/android.widget.LinearLayout/android.widget.FrameLayout/android.widget.FrameLayout/android.widget.HorizontalScrollView/android.widget.LinearLayout/android.widget.TabHost/android.widget.FrameLayout/android.widget.FrameLayout[2]/android.widget.LinearLayout/android.widget.FrameLayout[1]’).click()time.sleep(3)# 无限滑动i = 0while True: # 模拟滑动 print(’滑动ing...’) self.driver.swipe(self.start_x, self.start_y, self.start_x, self.start_y-self.distance) time.sleep(3) self.get_infos() # 获取视频发布者的名字 # 设置延时等待 time.sleep(4) # 判断是否退出 if self.nums is not None and self.nums == i:break i += 1 def get_infos(self):# 获取视频的各种信息:使用appium desktop定位元素print(self.driver.find_element_by_id(’ap’).text) # 发布者名字print(self.driver.find_element_by_id(’xm’).text) # 点赞数print(self.driver.find_element_by_id(’xn’).text) # 留言数print(self.driver.find_element_by_id(’oz’).text) # 视频名字,可能不存在,报错# # 点击【分享】坐标位置 671,1058# self.driver.tap([(671, 1058)])# time.sleep(2)# # 向左滑动露出 【复制链接】 580,1100 --> 200, 1100# self.driver.swipe(580,1100, 20, 200, 1100)# # self.driver.get_screenshot_as_file(’./a.png’) # 截图# # 点击【复制链接】 距离右边60 距离底边170 720-60,1280-170# self.driver.tap([(660, 1110)])# # self.driver.get_screenshot_as_file(’./b.png’) # 截图 def main(self):self.comments() # 点击一次屏幕,确保页面的展示time.sleep(2)self.scroll() # 滑动if __name__ == ’__main__’: action = DouyinAction(nums=5) action.main()
到此这篇关于python利用Appium自动控制移动设备并提取数据的文章就介绍到这了,更多相关python Appium提取数据内容请搜索好吧啦网以前的文章或继续浏览下面的相关文章希望大家以后多多支持好吧啦网!
相关文章: