1.adb常用命令
关闭adb服务:adb kill-server
启动adb服务 adb start-server
查询当前运行的所有设备 adb devices
可能在adb中存在多个虚拟设备运行 可以指定虚拟设备运行 -s 虚拟设备名称
重启设备 adb reboot –指定虚拟设备 adb -s 设备名称 reboot
查看日志 adb logcat 清除日志 adb logcat -c
进入linux shell下 adb shell 其中常用的linux命令 cd cat 等等 输入su可以获取超级管理员名称了 要确定是否有哪些命令 进入 system/bin目录 就知道了
传入文件到设备中 adb push 本地文件 远程目录
2.工具类示例代码
#!/usr/bin/evn python # -*- coding:utf-8 -*- # FileName adbtools.py # Author: HeyNiu # Created Time: 2016/9/19 \"\"\" adb 工具类 \"\"\" import os import platform import re import time #import utils.timetools class AdbTools(object): def __init__(self, device_id=\'\'): self.__system = platform.system() self.__find = \'\' self.__command = \'\' self.__device_id = device_id self.__get_find() self.__check_adb() self.__connection_devices() def __get_find(self): \"\"\" 判断系统类型,windows使用findstr,linux使用grep :return: \"\"\" # if self.__system is \"Windows\": #self.__find = \"findstr\" #else: #self.__find = \"grep\" def __check_adb(self): \"\"\" 检查adb 判断是否设置环境变量ANDROID_HOME :return: \"\"\" if \"ANDROID_HOME\" in os.environ: if self.__system == \"Windows\": path = os.path.join(os.environ[\"ANDROID_HOME\"], \"platform-tools\", \"adb.exe\") if os.path.exists(path): self.__command = path else: raise EnvironmentError( \"Adb not found in $ANDROID_HOME path: %s.\" % os.environ[\"ANDROID_HOME\"]) else: path = os.path.join(os.environ[\"ANDROID_HOME\"], \"platform-tools\", \"adb\") if os.path.exists(path): self.__command = path else: raise EnvironmentError( \"Adb not found in $ANDROID_HOME path: %s.\" % os.environ[\"ANDROID_HOME\"]) else: raise EnvironmentError( \"Adb not found in $ANDROID_HOME path: %s.\" % os.environ[\"ANDROID_HOME\"]) def __connection_devices(self): \"\"\" 连接指定设备,单个设备可不传device_id :return: \"\"\" if self.__device_id == \"\": return self.__device_id = \"-s %s\" % self.__device_id def adb(self, args): \"\"\" 执行adb命令 :param args:参数 :return: \"\"\" cmd = \"%s %s %s\" % (self.__command, self.__device_id, str(args)) # print(cmd) return os.popen(cmd) def shell(self, args): \"\"\" 执行adb shell命令 :param args:参数 :return: \"\"\" cmd = \"%s %s shell %s\" % (self.__command, self.__device_id, str(args)) # print(cmd) return os.popen(cmd) def mkdir(self, path): \"\"\" 创建目录 :param path: 路径 :return: \"\"\" return self.shell(\'mkdir %s\' % path) def get_devices(self): \"\"\" 获取设备列表 :return: \"\"\" l = self.adb(\'devices\').readlines() return (i.split()[0] for i in l if \'devices\' not in i and len(i) > 5) def get_current_application(self): \"\"\" 获取当前运行的应用信息 :return: \"\"\" return self.shell(\'dumpsys window w | %s \\/ | %s name=\' % (self.__find, self.__find)).read() def get_current_package(self): \"\"\" 获取当前运行app包名 :return: \"\"\" reg = re.compile(r\'name=(.+?)/\') return re.findall(reg, self.get_current_application())[0] def get_current_activity(self): \"\"\" 获取当前运行activity :return: package/activity \"\"\" reg = re.compile(r\'name=(.+?)\\)\') return re.findall(reg, self.get_current_application())[0] \'\'\'def __get_process(self, package_name): \"\"\" 获取进程信息 :param package_name: :return: \"\"\" if self.__system is \"Windows\": pid_command = self.shell(\"ps | %s %s$\" % (self.__find, package_name)).read() else: pid_command = self.shell(\"ps | %s -w %s\" % (self.__find, package_name)).read() return pid_command\'\'\' def process_exists(self, package_name): \"\"\" 返回进程是否存在 :param package_name: :return: \"\"\" process = self.__get_process(package_name) return package_name in process def get_pid(self, package_name): \"\"\" 获取pid :return: \"\"\" pid_command = self.__get_process(package_name) if pid_command == \'\': print(\"The process doesn\'t exist.\") return pid_command req = re.compile(r\"\\d+\") result = str(pid_command).split() result.remove(result[0]) return req.findall(\" \".join(result))[0] def get_uid(self, pid): \"\"\" 获取uid :param pid: :return: \"\"\" result = self.shell(\"cat /proc/%s/status\" % pid).readlines() for i in result: if \'uid\' in i.lower(): return i.split()[1] def get_flow_data_tcp(self, uid): \"\"\" 获取应用tcp流量 :return:(接收, 发送) \"\"\" tcp_rcv = self.shell(\"cat proc/uid_stat/%s/tcp_rcv\" % uid).read().split()[0] tcp_snd = self.shell(\"cat proc/uid_stat/%s/tcp_snd\" % uid).read().split()[0] return tcp_rcv, tcp_snd def get_flow_data_all(self, uid): \"\"\" 获取应用流量全部数据 包含该应用多个进程的所有数据 tcp udp等 (rx_bytes, tx_bytes) >> (接收, 发送) :param uid: :return:list(dict) \"\"\" all_data = [] d = {} data = self.shell(\"cat /proc/net/xt_qtaguid/stats | %s %s\" % (self.__find, uid)).readlines() for i in data: if not i.startswith(\'\\n\'): item = i.strip().split() d[\'idx\'] = item[0] d[\'iface\'] = item[1] d[\'acct_tag_hex\'] = item[2] d[\'uid_tag_int\'] = item[3] d[\'cnt_set\'] = item[4] d[\'rx_bytes\'] = item[5] d[\'rx_packets\'] = item[6] d[\'tx_bytes\'] = item[7] d[\'tx_packets\'] = item[8] d[\'rx_tcp_bytes\'] = item[9] d[\'rx_tcp_packets\'] = item[10] d[\'rx_udp_bytes\'] = item[11] d[\'rx_udp_packets\'] = item[12] d[\'rx_other_bytes\'] = item[13] d[\'rx_other_packets\'] = item[14] d[\'tx_tcp_bytes\'] = item[15] d[\'tx_tcp_packets\'] = item[16] d[\'tx_udp_bytes\'] = item[17] d[\'tx_udp_packets\'] = item[18] d[\'tx_other_bytes\'] = item[19] d[\'tx_other_packets\'] = item[20] all_data.append(d) d = {} return all_data @staticmethod def dump_apk(path): \"\"\" dump apk文件 :param path: apk路径 :return: \"\"\" # 检查build-tools是否添加到环境变量中 # 需要用到里面的aapt命令 l = os.environ[\'PATH\'].split(\';\') build_tools = False for i in l: if \'build-tools\' in i: build_tools = True if not build_tools: raise EnvironmentError(\"ANDROID_HOME BUILD-TOOLS COMMAND NOT FOUND.\\nPlease set the environment variable.\") return os.popen(\'aapt dump badging %s\' % (path,)) @staticmethod def dump_xml(path, filename): \"\"\" dump apk xml文件 :return: \"\"\" return os.popen(\'aapt dump xmlstrings %s %s\' % (path, filename)) def uiautomator_dump(self): \"\"\" 获取屏幕uiautomator xml文件 :return: \"\"\" return self.shell(\'uiautomator dump\').read().split()[-1] def pull(self, source, target): \"\"\" 从手机端拉取文件到电脑端 :return: \"\"\" self.adb(\'pull %s %s\' % (source, target)) def push(self, source, target): \"\"\" 从电脑端推送文件到手机端 :param source: :param target: :return: \"\"\" self.adb(\'push %s %s\' % (source, target)) def remove(self, path): \"\"\" 从手机端删除文件 :return: \"\"\" self.shell(\'rm %s\' % (path,)) def clear_app_data(self, package): \"\"\" 清理应用数据 :return: \"\"\" self.shell(\'pm clear %s\' % (package,)) def install(self, path): \"\"\" 安装apk文件 :return: \"\"\" # adb install 安装错误常见列表 errors = {\'INSTALL_FAILED_ALREADY_EXISTS\': \'程序已经存在\', \'INSTALL_DEVICES_NOT_FOUND\': \'找不到设备\', \'INSTALL_FAILED_DEVICE_OFFLINE\': \'设备离线\', \'INSTALL_FAILED_INVALID_APK\': \'无效的APK\', \'INSTALL_FAILED_INVALID_URI\': \'无效的链接\', \'INSTALL_FAILED_INSUFFICIENT_STORAGE\': \'没有足够的存储空间\', \'INSTALL_FAILED_DUPLICATE_PACKAGE\': \'已存在同名程序\', \'INSTALL_FAILED_NO_SHARED_USER\': \'要求的共享用户不存在\', \'INSTALL_FAILED_UPDATE_INCOMPATIBLE\': \'版本不能共存\', \'INSTALL_FAILED_SHARED_USER_INCOMPATIBLE\': \'需求的共享用户签名错误\', \'INSTALL_FAILED_MISSING_SHARED_LIBRARY\': \'需求的共享库已丢失\', \'INSTALL_FAILED_REPLACE_COULDNT_DELETE\': \'需求的共享库无效\', \'INSTALL_FAILED_DEXOPT\': \'dex优化验证失败\', \'INSTALL_FAILED_DEVICE_NOSPACE\': \'手机存储空间不足导致apk拷贝失败\', \'INSTALL_FAILED_DEVICE_COPY_FAILED\': \'文件拷贝失败\', \'INSTALL_FAILED_OLDER_SDK\': \'系统版本过旧\', \'INSTALL_FAILED_CONFLICTING_PROVIDER\': \'存在同名的内容提供者\', \'INSTALL_FAILED_NEWER_SDK\': \'系统版本过新\', \'INSTALL_FAILED_TEST_ONLY\': \'调用者不被允许测试的测试程序\', \'INSTALL_FAILED_CPU_ABI_INCOMPATIBLE\': \'包含的本机代码不兼容\', \'CPU_ABIINSTALL_FAILED_MISSING_FEATURE\': \'使用了一个无效的特性\', \'INSTALL_FAILED_CONTAINER_ERROR\': \'SD卡访问失败\', \'INSTALL_FAILED_INVALID_INSTALL_LOCATION\': \'无效的安装路径\', \'INSTALL_FAILED_MEDIA_UNAVAILABLE\': \'SD卡不存在\', \'INSTALL_FAILED_INTERNAL_ERROR\': \'系统问题导致安装失败\', \'INSTALL_PARSE_FAILED_NO_CERTIFICATES\': \'文件未通过认证 >> 设置开启未知来源\', \'INSTALL_PARSE_FAILED_INCONSISTENT_CERTIFICATES\': \'文件认证不一致 >> 先卸载原来的再安装\', \'INSTALL_FAILED_INVALID_ZIP_FILE\': \'非法的zip文件 >> 先卸载原来的再安装\', \'INSTALL_CANCELED_BY_USER\': \'需要用户确认才可进行安装\', \'INSTALL_FAILED_VERIFICATION_FAILURE\': \'验证失败 >> 尝试重启手机\', \'DEFAULT\': \'未知错误\' } print(\'Installing...\') l = self.adb(\'install -r %s\' % (path,)).read() if \'Success\' in l: print(\'Install Success\') if \'Failure\' in l: reg = re.compile(\'\\\\[(.+?)\\\\]\') key = re.findall(reg, l)[0] try: print(\'Install Failure >> %s\' % errors[key]) except KeyError: print(\'Install Failure >> %s\' % key) return l def uninstall(self, package): \"\"\" 卸载apk :param package: 包名 :return: \"\"\" print(\'Uninstalling...\') l = self.adb(\'uninstall %s\' % (package,)).read() print(l) def screenshot(self, target_path=\'\'): \"\"\" 手机截图 :param target_path: 目标路径 :return: \"\"\" format_time = utils.timetools.timestamp(\'%Y%m%d%H%M%S\') self.shell(\'screencap -p /sdcard/%s.png\' % (format_time,)) time.sleep(1) if target_path == \'\': self.pull(\'/sdcard/%s.png\' % (format_time,), os.path.expanduser(\'~\')) else: self.pull(\'/sdcard/%s.png\' % (format_time,), target_path) self.remove(\'/sdcard/%s.png\' % (format_time,)) def get_cache_logcat(self): \"\"\" 导出缓存日志 :return: \"\"\" return self.adb(\'logcat -v time -d\') def get_crash_logcat(self): \"\"\" 导出崩溃日志 :return: \"\"\" return self.adb(\'logcat -v time -d | %s AndroidRuntime\' % (self.__find,)) def clear_cache_logcat(self): \"\"\" 清理缓存区日志 :return: \"\"\" self.adb(\'logcat -c\') def get_device_time(self): \"\"\" 获取设备时间 :return: \"\"\" return self.shell(\'date\').read().strip() def ls(self, command): \"\"\" shell ls命令 :return: \"\"\" return self.shell(\'ls %s\' % (command,)).readlines() def file_exists(self, target): \"\"\" 判断文件在目标路径是否存在 :return: \"\"\" l = self.ls(target) for i in l: if i.strip() == target: return True return False def is_install(self, target_app): \"\"\" 判断目标app在设备上是否已安装 :param target_app: 目标app包名 :return: bool \"\"\" return target_app in self.shell(\'pm list packages %s\' % (target_app,)).read() def get_device_model(self): \"\"\" 获取设备型号 :return: \"\"\" return self.shell(\'getprop ro.product.model\').read().strip() def get_device_id(self): \"\"\" 获取设备id :return: \"\"\" return self.adb(\'get-serialno\').read().strip() def get_device_android_version(self): \"\"\" 获取设备Android版本 :return: \"\"\" return self.shell(\'getprop ro.build.version.release\').read().strip() def get_device_sdk_version(self): \"\"\" 获取设备SDK版本 :return: \"\"\" return self.shell(\'getprop ro.build.version.sdk\').read().strip() def get_device_mac_address(self): \"\"\" 获取设备MAC地址 :return: \"\"\" return self.shell(\'cat /sys/class/net/wlan0/address\').read().strip() def get_device_ip_address(self): \"\"\" 获取设备IP地址 pass: 适用WIFI 蜂窝数据 :return: \"\"\" if not self.get_wifi_state() and not self.get_data_state(): return l = self.shell(\'ip addr | %s global\' % self.__find).read() reg = re.compile(\'\\d+\\.\\d+\\.\\d+\\.\\d+\') return re.findall(reg, l)[0] def get_device_imei(self): \"\"\" 获取设备IMEI :return: \"\"\" sdk = self.get_device_sdk_version() # Android 5.0以下方法 if int(sdk) < 21: l = self.shell(\'dumpsys iphonesubinfo\').read() reg = re.compile(\'[0-9]{15}\') return re.findall(reg, l)[0] elif self.root(): l = self.shell(\'service call iphonesubinfo 1\').read() print(l) print(re.findall(re.compile(\"\'.+?\'\"), l)) imei = \'\' for i in re.findall(re.compile(\"\'.+?\'\"), l): imei += i.replace(\'.\', \'\').replace(\"\'\", \'\').replace(\' \', \'\') return imei else: print(\'The device not root.\') return \'\' def check_sim_card(self): \"\"\" 检查设备SIM卡 :return: \"\"\" return len(self.shell(\'getprop | %s gsm.operator.alpha]\' % self.__find).read().strip().split()[-1]) > 2 def get_device_operators(self): \"\"\" 获取运营商 :return: \"\"\" return self.shell(\'getprop | %s gsm.operator.alpha]\' % self.__find).read().strip().split()[-1] def get_device_state(self): \"\"\" 获取设备状态 :return: \"\"\" return self.adb(\'get-state\').read().strip() def get_display_state(self): \"\"\" 获取屏幕状态 :return: 亮屏/灭屏 \"\"\" l = self.shell(\'dumpsys power\').readlines() for i in l: if \'mScreenOn=\' in i: return i.split()[-1] == \'mScreenOn=true\' if \'Display Power\' in i: return \'ON\' in i.split(\'=\')[-1].upper() def get_screen_normal_size(self): \"\"\" 获取设备屏幕分辨率 >> 标配 :return: \"\"\" return self.shell(\'wm size\').read().strip().split()[-1].split(\'x\') def get_screen_reality_size(self): \"\"\" 获取设备屏幕分辨率 >> 实际分辨率 :return: \"\"\" x = 0 y = 0 l = self.shell(r\'getevent -p | %s -e \"0\"\' % self.__find).readlines() for n in l: if len(n.split()) > 0: if n.split()[0] == \'0035\': x = int(n.split()[7].split(\',\')[0]) elif n.split()[0] == \'0036\': y = int(n.split()[7].split(\',\')[0]) return x, y def get_device_interior_sdcard(self): \"\"\" 获取内部SD卡空间 :return: (path,total,used,free,block) \"\"\" return self.shell(\'df | %s \\/mnt\\/shell\\/emulated\' % self.__find).read().strip().split() def get_device_external_sdcard(self): \"\"\" 获取外部SD卡空间 :return: (path,total,used,free,block) \"\"\" return self.shell(\'df | %s \\/storage\' % self.__find).read().strip().split() def __fill_rom(self, path, stream, count): \"\"\" 填充数据 :param path: 填充地址 :param stream: 填充流大小 :param count: 填充次数 :return: \"\"\" self.shell(\'dd if=/dev/zero of=%s bs=%s count=%s\' % (path, stream, count)).read().strip() def fill_interior_sdcard(self, filename, size): \"\"\" 填充内置SD卡 :param filename: 文件名 :param size: 填充大小,单位byte :return: \"\"\" if size > 10485760: # 10m self.__fill_rom(\'sdcard/%s\' % filename, 10485760, size / 10485760) else: self.__fill_rom(\'sdcard/%s\' % filename, size, 1) def fill_external_sdcard(self, filename, size): \"\"\" 填充外置SD卡 :param filename: 文件名 :param size: 填充大小,单位byte :return: \"\"\" path = self.get_device_external_sdcard()[0] if size > 10485760: # 10m self.__fill_rom(\'%s/%s\' % (path, filename), 10485760, size / 10485760) else: self.__fill_rom(\'%s/%s\' % (path, filename), size, 1) def kill_process(self, pid): \"\"\" 杀死进程 pass: 一般需要权限不推荐使用 :return: \"\"\" return self.shell(\'kill %s\' % pid).read().strip() def quit_app(self, package): \"\"\" 退出应用 :return: \"\"\" return self.shell(\'am force-stop %s\' % package).read().strip() def reboot(self): \"\"\" 重启设备 :return: \"\"\" self.adb(\'reboot\') def recovery(self): \"\"\" 重启设备并进入recovery模式 :return: \"\"\" self.adb(\'reboot recovery\') def fastboot(self): \"\"\" 重启设备并进入fastboot模式 :return: \"\"\" self.adb(\'reboot bootloader\') def root(self): \"\"\" 获取root状态 :return: \"\"\" return \'not found\' not in self.shell(\'su -c ls -l /data/\').read().strip() def wifi(self, power): \"\"\" 开启/关闭wifi pass: 需要root权限 :return: \"\"\" if not self.root(): print(\'The device not root.\') return if power: self.shell(\'su -c svc wifi enable\').read().strip() else: self.shell(\'su -c svc wifi disable\').read().strip() def data(self, power): \"\"\" 开启/关闭蜂窝数据 pass: 需要root权限 :return: \"\"\" if not self.root(): print(\'The device not root.\') return if power: self.shell(\'su -c svc data enable\').read().strip() else: self.shell(\'su -c svc data disable\').read().strip() def get_wifi_state(self): \"\"\" 获取WiFi连接状态 :return: \"\"\" return \'enabled\' in self.shell(\'dumpsys wifi | %s ^Wi-Fi\' % self.__find).read().strip() def get_data_state(self): \"\"\" 获取移动网络连接状态 :return: \"\"\" return \'2\' in self.shell(\'dumpsys telephony.registry | %s mDataConnectionState\' % self.__find).read().strip() def get_network_state(self): \"\"\" 设备是否连上互联网 :return: \"\"\" return \'unknown host\' not in self.shell(\'ping -w 1 www.baidu.com\').read().strip() def get_wifi_password_list(self): \"\"\" 获取WIFI密码列表 :return: \"\"\" if not self.root(): print(\'The device not root.\') return [] l = re.findall(re.compile(\'ssid=\".+?\"\\s{3}psk=\".+?\"\'), self.shell(\'su -c cat /data/misc/wifi/*.conf\').read()) return [re.findall(re.compile(\'\".+?\"\'), i) for i in l] def call(self, number): \"\"\" 拨打电话 :param number: :return: \"\"\" self.shell(\'am start -a android.intent.action.CALL -d tel:%s\' % number) def open_url(self, url): \"\"\" 打开网页 :return: \"\"\" self.shell(\'am start -a android.intent.action.VIEW -d %s\' % url) def start_application(self, component): \"\"\" 启动一个应用 e.g: com.android.settings/com.android.settings.Settings \"\"\" self.shell(\"am start -n %s\" % component) def send_keyevent(self, keycode): \"\"\" 发送一个按键事件 https://developer.android.com/reference/android/view/KeyEvent.html :return: \"\"\" self.shell(\'input keyevent %s\' % keycode) def rotation_screen(self, param): \"\"\" 旋转屏幕 :param param: 0 >> 纵向,禁止自动旋转; 1 >> 自动旋转 :return: \"\"\" self.shell(\'/system/bin/content insert --uri content://settings/system --bind \' \'name:s:accelerometer_rotation --bind value:i:%s\' % param) def instrument(self, command): \"\"\" 启动instrument app :param command: 命令 :return: \"\"\" return self.shell(\'am instrument %s\' % command).read() def export_apk(self, package, target_path=\'\', timeout=5000): \"\"\" 从设备导出应用 :param timeout: 超时时间 :param target_path: 导出后apk存储路径 :param package: 包名 :return: \"\"\" num = 0 if target_path == \'\': self.adb(\'pull /data/app/%s-1/base.apk %s\' % (package, os.path.expanduser(\'~\'))) while 1: num += 1 if num <= timeout: if os.path.exists(os.path.join(os.path.expanduser(\'~\'), \'base.apk\')): os.rename(os.path.join(os.path.expanduser(\'~\'), \'base.apk\'), os.path.join(os.path.expanduser(\'~\'), \'%s.apk\' % package)) else: self.adb(\'pull /data/app/%s-1/base.apk %s\' % (package, target_path)) while 1: num += 1 if num <= timeout: if os.path.exists(os.path.join(os.path.expanduser(\'~\'), \'base.apk\')): os.rename(os.path.join(os.path.expanduser(\'~\'), \'base.apk\'), os.path.join(os.path.expanduser(\'~\'), \'%s.apk\' % package)) class KeyCode: KEYCODE_CALL = 5 # 拨号键 KEYCODE_ENDCALL = 6 # 挂机键 KEYCODE_HOME = 3 # Home键 KEYCODE_MENU = 82 # 菜单键 KEYCODE_BACK = 4 # 返回键 KEYCODE_SEARCH = 84 # 搜索键 KEYCODE_CAMERA = 27 # 拍照键 KEYCODE_FOCUS = 80 # 对焦键 KEYCODE_POWER = 26 # 电源键 KEYCODE_NOTIFICATION = 83 # 通知键 KEYCODE_MUTE = 91 # 话筒静音键 KEYCODE_VOLUME_MUTE = 164 # 扬声器静音键 KEYCODE_VOLUME_UP = 24 # 音量+键 KEYCODE_VOLUME_DOWN = 25 # 音量-键 KEYCODE_ENTER = 66 # 回车键 KEYCODE_ESCAPE = 111 # ESC键 KEYCODE_DPAD_CENTER = 23 # 导航键 >> 确定键 KEYCODE_DPAD_UP = 19 # 导航键 >> 向上 KEYCODE_DPAD_DOWN = 20 # 导航键 >> 向下 KEYCODE_DPAD_LEFT = 21 # 导航键 >> 向左 KEYCODE_DPAD_RIGHT = 22 # 导航键 >> 向右 KEYCODE_MOVE_HOME = 122 # 光标移动到开始键 KEYCODE_MOVE_END = 123 # 光标移动到末尾键 KEYCODE_PAGE_UP = 92 # 向上翻页键 KEYCODE_PAGE_DOWN = 93 # 向下翻页键 KEYCODE_DEL = 67 # 退格键 KEYCODE_FORWARD_DEL = 112 # 删除键 KEYCODE_INSERT = 124 # 插入键 KEYCODE_TAB = 61 # Tab键 KEYCODE_NUM_LOCK = 143 # 小键盘锁 KEYCODE_CAPS_LOCK = 115 # 大写锁定键 KEYCODE_BREAK = 121 # Break / Pause键 KEYCODE_SCROLL_LOCK = 116 # 滚动锁定键 KEYCODE_ZOOM_IN = 168 # 放大键 KEYCODE_ZOOM_OUT = 169 # 缩小键 KEYCODE_0 = 7 KEYCODE_1 = 8 KEYCODE_2 = 9 KEYCODE_3 = 10 KEYCODE_4 = 11 KEYCODE_5 = 12 KEYCODE_6 = 13 KEYCODE_7 = 14 KEYCODE_8 = 15 KEYCODE_9 = 16 KEYCODE_A = 29 KEYCODE_B = 30 KEYCODE_C = 31 KEYCODE_D = 32 KEYCODE_E = 33 KEYCODE_F = 34 KEYCODE_G = 35 KEYCODE_H = 36 KEYCODE_I = 37 KEYCODE_J = 38 KEYCODE_K = 39 KEYCODE_L = 40 KEYCODE_M = 41 KEYCODE_N = 42 KEYCODE_O = 43 KEYCODE_P = 44 KEYCODE_Q = 45 KEYCODE_R = 46 KEYCODE_S = 47 KEYCODE_T = 48 KEYCODE_U = 49 KEYCODE_V = 50 KEYCODE_W = 51 KEYCODE_X = 52 KEYCODE_Y = 53 KEYCODE_Z = 54 KEYCODE_PLUS = 81 # + KEYCODE_MINUS = 69 # - KEYCODE_STAR = 17 # * KEYCODE_SLASH = 76 # / KEYCODE_EQUALS = 70 # = KEYCODE_AT = 77 # @ KEYCODE_POUND = 18 # # KEYCODE_APOSTROPHE = 75 # \' KEYCODE_BACKSLASH = 73 # \\ KEYCODE_COMMA = 55 # , KEYCODE_PERIOD = 56 # . KEYCODE_LEFT_BRACKET = 71 # [ KEYCODE_RIGHT_BRACKET = 72 # ] KEYCODE_SEMICOLON = 74 # ; KEYCODE_GRAVE = 68 # ` KEYCODE_SPACE = 62 # 空格键 KEYCODE_MEDIA_PLAY = 126 # 多媒体键 >> 播放 KEYCODE_MEDIA_STOP = 86 # 多媒体键 >> 停止 KEYCODE_MEDIA_PAUSE = 127 # 多媒体键 >> 暂停 KEYCODE_MEDIA_PLAY_PAUSE = 85 # 多媒体键 >> 播放 / 暂停 KEYCODE_MEDIA_FAST_FORWARD = 90 # 多媒体键 >> 快进 KEYCODE_MEDIA_REWIND = 89 # 多媒体键 >> 快退 KEYCODE_MEDIA_NEXT = 87 # 多媒体键 >> 下一首 KEYCODE_MEDIA_PREVIOUS = 88 # 多媒体键 >> 上一首 KEYCODE_MEDIA_CLOSE = 128 # 多媒体键 >> 关闭 KEYCODE_MEDIA_EJECT = 129 # 多媒体键 >> 弹出 KEYCODE_MEDIA_RECORD = 130 # 多媒体键 >> 录音 if __name__ == \'__main__\': a = AdbTools() pass
以上就是Python常用工具类之adbtool示例代码的详细内容,更多关于Python adbtool的资料请关注其它相关文章!
© 版权声明
THE END
暂无评论内容