如何快速掌握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中的命令提示符CMD或PowerShell)是许多用户日常操作中常用的工具,无论是运行系统命令、执行脚本还是进行开发调试,都可能长时间面对这个窗口,默认的黑底绿字或蓝底白字虽然经典,但长时间使用容易造成视觉疲劳,或是在特定环境下(如高对比度模式)影响可读性,通过简单的设置,我们……

    2025年8月22日
    20400
  • 安全基线检查选开源工具,该关注哪些关键点?

    安全基线检查是保障信息系统安全的重要手段,通过对照标准化的安全要求,对系统、应用、网络等进行全面检测,及时发现并修复潜在风险,在开源工具的助力下,安全基线检查的效率和覆盖面得到显著提升,本文将介绍几款主流的开源安全基线检查工具,分析其功能特点及适用场景,帮助用户选择适合的工具构建安全防护体系,主流开源安全基线检……

    2025年11月28日
    1700
  • 如何快速了解产品核心功能并开始使用?

    核心功能是产品的基础服务,入口是用户接触功能的起点,两者共同构成用户体验的关键,需设计简洁直观的访问路径。

    2025年7月27日
    7600
  • 安全体系咨询大促,优惠力度有多大?

    企业构建坚实数字防线的关键机遇在数字化转型的浪潮下,企业面临的安全威胁日益复杂,从数据泄露到勒索攻击,安全风险已成为制约业务发展的核心挑战之一,为帮助企业高效构建安全体系,专业安全咨询服务近期推出限时大促活动,以高性价比方案助力企业夯实安全基础,提升风险应对能力,本文将围绕安全体系咨询的核心价值、大促服务内容及……

    2025年11月23日
    1600
  • SCALE命令如何改变工作流程?

    SCALE命令用于按指定比例因子放大或缩小选定对象尺寸,可基于基点进行整体或非均匀比例变换,改变几何对象实际大小。

    2025年8月9日
    5500

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信