如何快速掌握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

相关推荐

  • 如何快速掌握ADB Shell命令必备技巧?

    ADB Shell是Android Debug Bridge的命令行界面工具,允许开发者通过电脑连接Android设备或模拟器,直接执行各种系统命令进行调试、文件管理、应用控制等操作。

    2025年7月27日
    16600
  • A类地址网络号范围是什么?

    在计算机网络中,IP地址是设备在网络中的唯一标识,而A类地址作为最早定义的IP地址类别之一,在互联网发展中扮演了重要角色,A类地址的网络号部分具有独特的结构和应用场景,理解其特性对于网络规划和地址管理至关重要,A类地址的基本概念IP地址根据网络号和主机号的位数被划分为A、B、C、D、E五类,其中A类地址是专为大……

    2025年11月22日
    10100
  • 安丘人脸识别门禁系统哪家好?

    在选择安丘人脸识别门禁系统时,企业需综合考虑技术成熟度、产品稳定性、本地化服务能力及性价比等多重因素,安丘作为山东省潍坊市下辖的县级市,近年来在智慧城市建设中积极推进智能化安防系统,人脸识别门禁系统已成为社区、办公楼、校园等场景的刚需设备,本文将从核心选型标准、主流品牌对比及本地服务支持三个维度,为安丘用户提供……

    2025年12月2日
    9400
  • jvm命令行怎么编程

    命令行中,可以使用javac编译Java文件,java运行字节码,通过

    2025年8月15日
    12100
  • 安全加固报告打折,质量缩水还是促销噱头?

    安全加固报告作为企业风险防控体系的关键文档,其质量直接关系到安全措施的有效性与企业资产的安全性,然而当前市场中,部分安全加固报告存在“打折”现象——内容缩水、细节模糊、承诺过度,导致报告从“安全导航”沦为“形式文书”,这种“打折”不仅削弱了报告的实际价值,更可能让企业在虚假的安全感中忽视真实风险,需引起行业高度……

    2025年11月9日
    11800

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信