AirtestProject 答疑第三期 | 使用 Airtest 最常见的 8 大问题
此文章来源于项目官方公众号:“AirtestProject”
版权声明:允许转载,但转载必须保留原链接;请勿用作商业或者非法用途
1.ImportError: DLL load failed: 找不到指定模块
常见的 DLL 报错会出现在以下 2 种情况中:
① 在 cv2
模块报 ImportError: DLL load failed: 找不到指定模块
的错:
根本原因应该是 DLL 文件的缺失,你可以直接下载一个最新版本的 AirtestIDE,在解压后的目录中找到 api-ms-win-downlevel-shlwapi-l1-1-0.dll
和 IEShims.dll
两个 DLL 文件(或者自行在网上搜索这俩个 DLL 文件也是可以的),然后将它们复制到 C:\Windows\System32
目录,重新运行代码即可解决。
② 若在 win.py
中 import win32api
时报 DLL load failed
:
<Module>
import win32api
ImportError: DLL load failed: 找不到指定的程序。
建议您运行下列指令,更新为 223 版本的 pywin32
:
pip uninstall pywin32
pip install pywin32==223
2. 各种常用的 pip 命令
① 安装 Airtest 库: pip install airtest
② 安装 poco 库: pip install pocoui
③ 更新 Airtest: pip install -U airtest
④ 更新 Poco: pip install -U pocoui
⑤ 卸载 Airtest 库: pip uninstall airtest
特别注意:Poco 依赖库是 pocoui
而不是 poco
,如果你发现你的环境里面同时存在 poco
和 pocoui
,请务必把 poco
卸载了,留下 pocoui
即可。
另外,如果你的电脑同时安装了 python3 和 python2 ,在不同 python 环境里面使用 pip 命令时可以使用如下方法:
# Python2
pip2 install XXX
python2 -m pip install XXX
# Python3
pip3 install XXX
python3 -m pip install XXX
3.查询 Airtest 版本号的方法
查询本地环境中的 Airtest 版本可以使用如下俩种方法:
① 使用 pip list
命令,找到 Airtest 那一行查看。
② 使用 airtest version
命令,但注意该命令只对 1.1.2 以上的 Airtest 版本生效。
4.自定义截图压缩精度
当 Airtest 版本≥1.1.2 时,我们可以自定义截图精度:
① 在本地运行脚本时自定义:
# quality取值[1,99],airtest默认取10,希望获得更高精度可以取值75
airtest run xxx --compress quality
② 在脚本中自定义(优先级高于在命令行自定义):
自定义全局的截图压缩精度:
import airtest.core.api import *
ST.SNAPSHOT_QUALITY = xxx
自定义单张截图的压缩精度:
snapshot(quality=my_quality)
5.Airtest 支持多设备运行吗
Airtest 支持 Android iOS 的多设备运行 ,但是这些目前仅用在我们的收费的小型机柜方案私有云中 ,外放的开源版本可以自己实现。
另外,Airtest 还支持 Android 设备的 多机协作功能 ,实操案例可以参考往期推文:“多机协作” -- 微信互加好友案例分析。
6.怎样输入随机数字
首先我们要利用 python 的 random
函数创建出符合要求的随机数;比如想要随机输入 20-100 的 1 个整数型随机数:
import random
r = random.randint(20,100)
然后使用 text
接口完成随机数的输入,但要注意的是,text
接口传入的是一个字符串类型,所以把随机数传入 text
接口之前,要把刚才创建的随机数转化为字符串类型:
text(str(random.randint(20,100)))
这样我们就可以完成输入随机数字的需求啦。
7.如何获取节点的 text 属性并打印
Poco 提供了 get_text()
和 get_name()
等方法让我们去读取 UI 的属性值,例如我们可以这样获取并打印下面这个节点的 text
属性和 name
属性:
a = poco(text="联系人")
print(a.get_text()) # 打印出:联系人
print(a.get_name()) # 打印出:android.widget.TextView
8.模拟器勾选上连接参数之后还是连不上
之前跟大家强调过,连接模拟器的时候,我们需要勾选上一些备选的连接参数才能连接上模拟器,或者不让模拟器黑屏。
比如连接雷电时需要勾选上 Use javacap
,而连接夜神的时候需要勾选上 Use javacap
和 Use ADB orientation
这俩个选项。
但是在一些版本的模拟器中,即使勾选上了连接参数,仍然可能连接不上模拟器,并出现如下的报错:
这是因为在连接这些版本的模拟器时,不能自动安装上 Yosemite.apk
,我们可以通过手动安装这个 apk
,再重新连接模拟器即可。
Airtest 官网:airtest.netease.com/
Airtest 教程官网:airtest.doc.io.netease.com/
搭建企业私有云服务:airlab.163.com/b2b
关注下方公众号,可以查看更多往期教程,回复 “交流群” 可以加入我们的官方开发者交流群