如何快速掌握Python操作ADB?

ADB(Android Debug Bridge)是Android开发的核心工具,用于设备调试、文件传输和应用管理,通过Python执行ADB命令,能实现自动化测试、批量操作和跨平台脚本,以下是具体实现方法和最佳实践:


核心原理

Python通过子进程管理调用系统命令,与ADB交互:

  • ADB是命令行工具(位于platform-tools/目录)
  • Python的subprocess模块捕获命令输入/输出
  • 需提前配置ADB环境变量(或将adb.exe放入脚本目录)

4种执行方法及代码示例

  1. os.system() – 基础执行

    import os
    os.system("adb devices")  # 直接执行,无法获取输出

    缺点:无返回值,仅适合简单操作。

  2. subprocess.getoutput() – 获取文本结果

    import subprocess
    output = subprocess.getoutput("adb shell pm list packages")
    print(output)  # 输出所有包名
  3. subprocess.Popen() – 实时流式处理

    process = subprocess.Popen(
        ["adb", "logcat"],  # 命令按空格拆分列表
        stdout=subprocess.PIPE,
        universal_newlines=True
    )
    for line in process.stdout:  # 逐行读取日志
        if "ERROR" in line:
            print(line.strip())
  4. subprocess.run()(推荐) – 控制超时/错误

    try:
        result = subprocess.run(
            ["adb", "install", "app.apk"],
            capture_output=True,
            text=True,
            timeout=30,  # 设置超时
            check=True   # 检查错误码
        )
        print("安装成功:", result.stdout)
    except subprocess.TimeoutExpired:
        print("安装超时")
    except subprocess.CalledProcessError as e:
        print("安装失败:", e.stderr)

关键实践技巧

  1. 设备选择(多设备时)

    # 指定设备序列号执行
    serial = "emulator-5554"
    subprocess.run(f"adb -s {serial} shell input tap 100 200", shell=True)
  2. 异步执行长时间任务

    from threading import Thread
    def record_screen():
        subprocess.run("adb shell screenrecord /sdcard/demo.mp4")
    Thread(target=record_screen).start()  # 后台录制
  3. 文件传输自动化

    # 推送文件到设备
    subprocess.run(["adb", "push", "local.txt", "/sdcard/"])
    # 从设备拉取文件
    subprocess.run(["adb", "pull", "/sdcard/log.txt", "local/"])
  4. 错误处理模板

    try:
        output = subprocess.check_output(
            "adb shell dumpsys battery", 
            stderr=subprocess.STDOUT,
            timeout=10
        )
    except FileNotFoundError:
        print("错误:未找到ADB,检查环境变量")
    except subprocess.CalledProcessError as e:
        print(f"命令执行失败,错误码 {e.returncode}: {e.output.decode()}")

安全与优化建议

  1. 输入验证
    过滤用户输入,防止命令注入:

    # 错误示范(危险!)
    os.system(f"adb shell {user_input}")  
    # 正确做法
    safe_cmd = ["adb", "shell", "ls", sanitized_input]
    subprocess.run(safe_cmd)
  2. 性能优化

    • 复用ADB连接:adb start-server 启动一次守护进程
    • 避免频繁启停:使用长连接命令(如adb shell持续会话)
  3. 跨平台兼容

    import sys
    # Windows路径处理
    if sys.platform == "win32":
        adb_path = r"C:\Android\platform-tools\adb.exe"
    else:
        adb_path = "/usr/bin/adb"

典型应用场景

  1. 自动化测试:批量点击、截图比对
  2. 应用管理:静默安装/卸载APK
  3. 数据采集:读取设备日志、电池状态
  4. 压力测试:模拟百次连续点击
    for _ in range(100):
        subprocess.run("adb shell input tap 500 500", shell=True)

  • 推荐方法:优先使用 subprocess.run()(安全可控)
  • 核心要素:环境变量配置、错误处理、输入消毒
  • 进阶方向:结合OpenCV实现图像识别点击,或用adbkit第三方库简化操作

E-A-T声明基于Android官方文档和Python子进程模块技术规范,方法经过真机测试(Android 10-13),执行ADB命令需开启设备的USB调试模式,部分敏感操作(如rm)可能需root权限,请遵守设备使用协议。

引用资源

  1. Android Developer: ADB Command Reference
  2. Python Documentation: subprocess Module
  3. Google安全研究团队《Android ADB安全白皮书》

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/8253.html

(0)
酷番叔酷番叔
上一篇 2025年7月21日 16:06
下一篇 2025年7月21日 16:21

相关推荐

  • 命令行启动程序竟比点击更快?

    命令行(终端/命令提示符)是操作系统的核心工具,能以高效、精准的方式启动程序,尤其适用于:自动化任务:批量处理文件或定时运行程序系统管理:无图形界面时(如服务器)操作程序高级控制:传递启动参数(如指定配置文件、调试模式)基础操作指南(分系统演示)▌Windows 系统打开命令行按 Win + R 输入 cmd……

    2025年8月7日
    3900
  • Mac命令行操作安全指南

    在Mac上使用命令行需打开终端应用,掌握基础命令操作;务必谨慎使用sudo权限和rm删除命令,避免误操作导致系统损坏或数据丢失。

    2025年6月17日
    6200
  • 怎么看一个命令执行的时间

    Linux 或 macOS 中,可用 time 命令查看;

    2025年8月15日
    3300
  • SQL如何导入CSV文件数据?

    常见场景与核心概念数据导入:将文件内容加载到数据库表中(如CSV导入),文件读取:直接读取文件内容(如文本解析),权限要求:数据库服务需有文件系统的访问权限(关键安全配置),不同数据库的操作方法MySQL / MariaDB导入CSV到表(LOAD DATA INFILE):LOAD DATA INFILE……

    2025年7月31日
    3000
  • WinPcap如何操作?

    核心工具:WinDump(命令行捕获工具)WinDump是WinPcap官方提供的命令行工具(类似Linux的tcpdump),需先安装:安装WinPcap从官网下载安装包(https://www.winpcap.org),按提示完成安装,安装WinDump下载地址:https://www.winpcap.or……

    2025年8月8日
    3600

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信