Python3+Appium安装及Appium模拟微信登录方法详解


Posted in Python onFebruary 16, 2021

一、Appium安装

我们知道selenium是桌面浏览器自动化操作工具(Web Browser Automation)

appium是继承selenium自动化思想旨在使手机app操作也能自动化的工具(Mobile App Automation Made Awesome)。

appium可以通过Desktop App和npm两种方式安装。Desktop App类似于selenium IDE提供一个图形界面式操作工具;npm类似于selenium就只能使用命令行。

如果对appium还不太熟悉,推荐使用Desktop App安装,这样一些操作我们可以使用Desktop App来输出代码,写代码时就有个参考。

1.1 安装Android SDK

要想操作安卓手机需要Android SDK,所以在安装appium之前先安装Android SDK。

推荐直接安装Android  Studio然后使用Android Studio安装SDK(太慢可通过图中HTTP Proxy设置代理)。

菜单----Tools----SDK Manager,钩选自己要安装的版本点击Apply进行下载即可。

Python3+Appium安装及Appium模拟微信登录方法详解

Android SDK安装完成后,新建ANDROID_HOME环境变量,值为上图Android SDK Location的目录(我这里是“D:\Language\ASDK”)

Python3+Appium安装及Appium模拟微信登录方法详解

1.2 通过Desktop App安装(推荐)

下载地址:https://github.com/appium/appium-desktop/releases

选择操作系统对应版本下载,Windows直接双击安装即可。 

Python3+Appium安装及Appium模拟微信登录方法详解

1.3 通过npm安装

1.3.1 安装nodejs

appium本质是一个nodejs库所以要先安装nodejs,然后使用npm安装。

nodejs下载地址:https://nodejs.org/zh-cn/download/

下载zip包解压到自己想放的目录,然后把该目录加入Path环境变量即可。

1.3.2 安装appium

npm install -g appium

 安装appium的过程中安装chromedriver时会连接google网站上去(报错RequestError: Error: connect ETIMEDOUT 216.58.220.208:443),所以可能你需要参考以下命令设置一下npm代理

# 设置代理
npm config set proxy http://127.0.0.1:1080
npm config set https-proxy http://127.0.0.1:1080

# 如果代理需要用户名密码
npm config set proxy http://username:password@127.0.0.1:1080
npm config set https-proxy http://username:password@127.0.0.1:1080

# 注册npm仓库
npm config set registry https://registry.npmjs.org
# 查看当前配置项npm config getnpm config get proxy
# 删除代理配置
npm config delete proxy
npm config delete https-proxy

配置本质上会存放到“C:\Users\你的用户名\.npmrc”内,所以也可以直接修改该文件。

1.3.3 使用appinum-doctor确认环境配置无误

npm install -g appium-doctor
appium-doctor --android

Python3+Appium安装及Appium模拟微信登录方法详解

 二、手机连接appium

2.1 启动appium服务

如果是通过npm安装,appium会被安装到nodejs目录下,直接使用appium命令启动即可

Python3+Appium安装及Appium模拟微信登录方法详解

我这里使用Desktop App方式安装,安装完成后双击桌面上的图标界面如下:

Python3+Appium安装及Appium模拟微信登录方法详解

我们使用默认配置都不修改,直接点击“Start Server”按钮启动 

Python3+Appium安装及Appium模拟微信登录方法详解

2.2 手机使用数据线连接电脑

使用数据线把手机连接到开启appium的电脑,开启usb调试功能。可使用adb命令列出设备确保连接成功

adb devices -l

Python3+Appium安装及Appium模拟微信登录方法详解

三、 使用示例

下边以python3+appium打开微信并登录进行演示。python操作appium是通过向appnium的监听端口发报文实现的,所以python不用安装什么appium库。

3.1 Desktop App打开微信并登录

Python3+Appium安装及Appium模拟微信登录方法详解

添加以下四项值,完后点击“Start Session”。

platformName---设备平台。填Android或IOS

deviceName----设备名。按上边adb查出的设备名填写即可

appPackage----要启动的app的包名。微信是"com.tencent.mm"

appActivity----要启动的界面。微信启动界面是".ui.LauncherUI"

{
 "platformName": "Android",
 "deviceName": "HWEVA",
 "appPackage": "com.tencent.mm",
 "appActivity": ".ui.LauncherUI"
}

Python3+Appium安装及Appium模拟微信登录方法详解

选择xml控件,对应部份就会高亮显示。

Python3+Appium安装及Appium模拟微信登录方法详解

点击开始录制,然后在该appium界面上操作(注意不是自己直接在手机上操作),操作过程就会被记录下来然后可输出该过程对应的python代码

Python3+Appium安装及Appium模拟微信登录方法详解

操作过程就会被记录下来,在Recorder下拉选择语言即可输出操作对应的代码

Python3+Appium安装及Appium模拟微信登录方法详解

3.2 全代码自动化登录实现

Desktop App已给出界面内操作的代码,全代码自动化主要的其实只是打开该界面的代码。

首先我们先安装两个依赖库

pip install Appium-Python-Client Selenium

代码补全如下,Appium-Python-Client继承自Selenium所以使用方法和selenium是很类似的,更多api操作见:https://github.com/appium/python-client

from appium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC

# appium服务监听地址
server='http://localhost:4723/wd/hub'
# app启动参数
desired_caps={
 "platformName": "Android",
 "deviceName": "HWEVA",
 "appPackage": "com.tencent.mm",
 "appActivity": ".ui.LauncherUI"
}

# 驱动
driver = webdriver.Remote(server,desired_caps)
wait = WebDriverWait(driver,30)
# 获取登录按钮
login_btn = wait.until(EC.presence_of_element_located((By.ID,"com.tencent.mm:id/drp")))
# 点击登录按钮
login_btn.click()
# 获取手机号文本框
phone_text = wait.until(EC.presence_of_element_located((By.ID,"com.tencent.mm:id/ji")))
# 填写手机号文本框
phone_text.send_keys("18888888888")

更多关于Appium的使用方法请查看下面的相关链接

Python 相关文章推荐
python根据时间生成mongodb的ObjectId的方法
Mar 13 Python
Python基于正则表达式实现检查文件内容的方法【文件检索】
Aug 30 Python
Python闭包之返回函数的函数用法示例
Jan 27 Python
Python cookbook(数据结构与算法)让字典保持有序的方法
Feb 18 Python
python模块smtplib实现纯文本邮件发送功能
May 22 Python
python脚本实现验证码识别
Jun 07 Python
Pycharm远程调试原理及具体配置详解
Aug 08 Python
python+Django实现防止SQL注入的办法
Oct 31 Python
Python列表解析操作实例总结
Feb 26 Python
Keras实现支持masking的Flatten层代码
Jun 16 Python
Python正则表达式高级使用方法汇总
Jun 18 Python
PyTorch 如何检查模型梯度是否可导
Jun 05 Python
Python3使用Selenium获取session和token方法详解
Feb 16 #Python
Python3+PyCharm+Django+Django REST framework配置与简单开发教程
Feb 16 #Python
PyCharm+Miniconda3安装配置教程详解
Feb 16 #Python
Python3+Django get/post请求实现教程详解
Feb 16 #Python
Python3+Flask安装使用教程详解
Feb 16 #Python
Python基于爬虫实现全网搜索并下载音乐
Feb 14 #Python
Python LMDB库的使用示例
Feb 14 #Python
You might like
浅析关于PHP位运算的简单权限设计
2013/06/30 PHP
PHP内核探索:变量存储与类型使用说明
2014/01/30 PHP
php技术实现加载字体并保存成图片
2015/07/27 PHP
php结合ajax实现手机发红包的案例
2016/10/13 PHP
thinkPHP中钩子的使用方法实例分析
2017/11/16 PHP
laravel-admin 实现给grid的列添加行数序号的方法
2019/10/08 PHP
thinkphp框架使用JWTtoken的方法详解
2019/10/10 PHP
jquery的父子兄弟节点查找示例代码
2014/03/03 Javascript
分享两段简单的JS代码防止SQL注入
2016/04/12 Javascript
js实现悬浮窗效果(支持拖动)
2017/03/09 Javascript
react native仿微信PopupWindow效果的实例代码
2017/08/07 Javascript
JavaScript实现的搜索及高亮显示功能示例
2017/08/14 Javascript
AngularJS 控制器 controller的详解
2017/10/17 Javascript
ES6中字符串string常用的新增方法小结
2017/11/07 Javascript
jQuery中元素选择器(element)简单用法示例
2018/05/14 jQuery
如何根据业务封装自己的功能组件
2019/04/19 Javascript
json数据格式常见操作示例
2019/06/13 Javascript
vue路由传参的基本实现方式小结【三种方式】
2020/02/05 Javascript
JavaScript实现与web通信的方法详解
2020/08/07 Javascript
Python守护线程用法实例
2017/06/23 Python
python+opencv实现动态物体追踪
2018/01/09 Python
Python使用numpy实现BP神经网络
2018/03/10 Python
python实现ID3决策树算法
2018/08/29 Python
使用Matplotlib 绘制精美的数学图形例子
2019/12/13 Python
python框架Django实战商城项目之工程搭建过程图文详解
2020/03/09 Python
html5中localStorage本地存储的简单使用
2017/06/16 HTML / CSS
详解html5 canvas常用api总结(二)--绘图API
2016/12/14 HTML / CSS
html5小程序飞入购物车(抛物线绘制运动轨迹点)
2020/10/19 HTML / CSS
Spartoo葡萄牙鞋类网站:线上销售鞋履与时尚配饰
2017/01/11 全球购物
伯克斯奥特莱斯:Burkes Outlet
2019/03/30 全球购物
King Apparel官网:英国街头服饰品牌
2019/09/05 全球购物
Static Nested Class 和 Inner Class的不同
2013/11/28 面试题
爱心捐赠活动简讯
2015/07/20 职场文书
百年校庆感言
2015/08/01 职场文书
vue3获取当前路由地址
2022/02/18 Vue.js
设置IIS Express并发数
2022/07/07 Servers