
本文介绍如何使用 androidviewclient/culebra 实现 python 对多台 android 设备(模拟器或真机)的低耦合、高并发控制,无需依赖 appium 多服务部署,支持差异化任务编排与原生 ui 自动化。
本文介绍如何使用 androidviewclient/culebra 实现 python 对多台 android 设备(模拟器或真机)的低耦合、高并发控制,无需依赖 appium 多服务部署,支持差异化任务编排与原生 ui 自动化。
在自动化测试、批量设备验证或分布式爬虫等场景中,常需用 Python 同时驱动多台 Android 设备执行不同逻辑路径的任务(例如:设备 A 登录并提交表单,设备 B 播放视频并截图,设备 C 扫描二维码)。传统方案如 Appium + 多实例服务器虽可行,但面临端口冲突、会话隔离复杂、资源开销大、调试困难等问题——尤其在启动多个 Appium 服务时易出现 systemPort/chromedriverPort 冲突、ADB 设备绑定错乱等典型故障。
更轻量、更稳健的替代方案是 AndroidViewClient/culebra:一个基于纯 ADB 协议、无需额外服务进程、天然支持多设备并发的 Python 库。它通过为每个设备创建独立的 Device 实例,直接调用 adb shell uiautomator 和 dumpsys 获取控件树,并提供类 Selenium 的链式操作接口,真正实现“一套脚本、多端异步、按需定制”。
✅ 核心优势
- 零服务依赖:不启动 Appium/Selenium 服务,避免端口管理与进程维护负担;
- 真并行控制:每个 Device 实例独占 ADB 连接,自动识别 -s <serial>,天然隔离;
- 差异化任务:可为每台设备定义独立逻辑(如不同账号登录、不同点击路径),无共享状态干扰;
- 轻量稳定:基于 ADB 原生命令,兼容 Android 5.0+,对模拟器(AVD/Genymotion)和真机均友好。
? 快速上手示例
首先安装依赖:
pip install androidviewclient
以下是一个完整示例:检测所有已连接设备,并为每台设备启动独立线程,执行差异化操作(如获取设备信息 + 点击桌面图标):
立即学习“Python免费学习笔记(深入)”;
from com.dtmilano.android.viewclient import ViewClient
from threading import Thread
import subprocess
import time
def get_connected_devices():
"""获取所有已连接设备序列号"""
try:
output = subprocess.check_output(['adb', 'devices']).decode('utf-8')
devices = [line.split()[0] for line in output.strip().split('\n')[1:] if line.strip() and '\tdevice' in line]
return devices
except Exception as e:
print(f"获取设备列表失败: {e}")
return []
def control_device(device_id: str):
"""为单台设备执行专属操作"""
print(f"[{device_id}] 开始初始化...")
# 创建 Device + ViewClient 实例(自动绑定指定设备)
device, serialno = ViewClient.connectToDeviceOrExit(serialno=device_id)
vc = ViewClient(device, serialno, autodump=False)
try:
# 示例1:获取设备基本信息
build_version = device.shell('getprop ro.build.version.release').strip()
model = device.shell('getprop ro.product.model').strip()
print(f"[{device_id}] Android {build_version}, Model: {model}")
# 示例2:启动 Settings 应用(差异化任务起点)
device.startActivity('com.android.settings/.Settings')
time.sleep(2)
# 示例3:查找并点击「关于手机」(需确保界面已加载)
about_btn = vc.findViewWithTextOrRaise('关于手机')
about_btn.touch()
print(f"[{device_id}] 已完成定制操作")
except Exception as e:
print(f"[{device_id}] 执行异常: {e}")
finally:
vc.quit()
# 主流程:并行控制所有设备
if __name__ == '__main__':
devices = get_connected_devices()
if not devices:
print("⚠️ 未检测到任何已连接的 Android 设备,请检查 adb devices 输出")
exit(1)
print(f"✅ 发现 {len(devices)} 台设备: {devices}")
# 启动线程池,每台设备独立运行
threads = []
for dev_id in devices:
t = Thread(target=control_device, args=(dev_id,))
t.start()
threads.append(t)
# 等待全部完成
for t in threads:
t.join()
print("? 所有设备任务执行完毕")⚠️ 关键注意事项
- ADB 权限与状态:确保 adb devices 能列出所有目标设备(状态为 device),且每台设备已开启 USB 调试/模拟器已就绪;
- UI 元素稳定性:culebra 依赖当前界面控件树,若目标页面动态加载或存在动画,建议添加 vc.sleep(1) 或 vc.waitUntilIdle() 提升鲁棒性;
- 线程安全:ViewClient 实例不可跨线程复用,务必为每个线程创建独立 device 和 vc;
- 性能优化:高频操作(如循环点击)可启用 autodump=False + 手动 vc.dump() 控制快照时机,减少 ADB 开销;
- 扩展能力:结合 culebra 生成的 GUI 录制脚本(culebra --gui),可快速构建可视化多设备测试流。
? 总结
相比 Appium 多服务架构,AndroidViewClient/culebra 以更底层、更简洁的方式解决了多设备并行控制的核心痛点。它不引入额外服务层,规避了端口争抢与会话混淆风险,同时保留了完整的 UI 自动化能力。对于需要灵活调度、逻辑各异、追求稳定交付的 Android 批量任务场景,它是值得优先验证的生产级方案。后续可进一步封装为设备管理器类,集成日志隔离、异常重试、结果聚合等功能,构建企业级多端自动化中台基础。










