adb logcat 打印输出

深圳公司的同事在测试的时候遇到一些bug 我这边没办法重现 于是只能远程协助查看log来看看问题到底出在哪 

遇到如下问题:

adb server is out of date.  killing...
ADB server didn't ACK
* failed to start daemon *
error: unknown host service

 

使用adb时,若出上面的错,使用adb kill-server是没有用的,因为此时是其他进程的监听了端口,而不是adb。我用cmd+命令管理器解决:

输入netstat -ano | findstr "5037"  adb就是使用此端口号

找到下列进程

  TCP    127.0.0.1:5037         0.0.0.0:0              LISTENING       4236  

  TCP    127.0.0.1:5037         127.0.0.1:49422        ESTABLISHED     4236  

  TCP    127.0.0.1:49422        127.0.0.1:5037         ESTABLISHED     3840  

此时把4236这个进程结束就行了。

TASKLIST | findstr "4236"

我的是被一个叫tadb.exe的挟持了,貌似是qqmusic的进程,结束它,over

吐槽一个 现在占用adb端口的程序越来越多了
写道
adb logcat -d -s xxx>xxx.log *:E

 

在 Python 中可以使用 `subprocess` 模块来执行系统命令,从而获取 adb logcat 命令的实时输出。具体的代码如下: ```python import subprocess adb_cmd = ["adb", "logcat", "-v", "time"] adb_process = subprocess.Popen(adb_cmd, stdout=subprocess.PIPE) while True: line = adb_process.stdout.readline() if not line: break print(line.strip()) ``` 这段代码首先定义了一个 `adb_cmd` 列表,其中包含了执行 adb logcat 命令所需的参数。然后使用 `subprocess.Popen` 函数来执行该命令,并将其输出重定向到一个管道中。接下来使用一个无限循环来实时读取管道中的输出,并将其打印到控制台中。 需要注意的是,在 Windows 系统中,`adb_process.stdout.readline()` 方法会在读取到换行符 `\n` 时才返回。因此,如果 adb logcat 命令的输出中没有换行符,那么该方法会一直阻塞,导致程序无法正常运行。解决方法是在调用 `adb` 命令时添加一个参数 `-B`,表示使用二进制模式输出日志信息,这样就可以避免该问题。具体的代码如下: ```python import subprocess adb_cmd = ["adb", "logcat", "-v", "time", "-B"] adb_process = subprocess.Popen(adb_cmd, stdout=subprocess.PIPE) while True: line = adb_process.stdout.readline() if not line: break print(line.strip().decode("utf-8", errors="ignore")) ``` 这个版本的代码在读取输出时,使用 `strip()` 方法去除多余的空格和换行符,并调用 `decode()` 方法将字节字符串转换为 Unicode 字符串。`decode()` 方法中的参数 `errors="ignore"` 表示在遇到编码错误时忽略错误,避免程序异常退出。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值