路过的大佬看过来airtest.core.error.AdbError: stdout[b‘‘] stderr[b‘‘]

我自己安装了airtest库,这是个安卓设备录屏的简单代码,运行会报错,代码正文、报错信息在下面,有大佬可以帮帮我吗,不胜感激

# coding = utf-8

import time
import airtest
import os
import threading
from airtest.core.api import connect_device
from airtest.core.android.adb import ADB
import subprocess


def ues_adb(command):
    try:
        result = subprocess.run(command.split(), stdout=subprocess.PIPE, stderr=subprocess.PIPE)
        if result.returncode == 0:
            print('执行成功')
            return result
        else:
            print("执行失败")
    except FileExistsError:
        print("未找到adb,请确保adb已经安装,且在环境变量中")


b = ues_adb("adb devices")
c = b.stdout.decode(encoding="utf-8")
print(c)
lines = c.split("\n")
device_serial = 0
for line in lines:
    if line.strip() and not line.startswith("List of devices attached"):
        parts = line.split("\t")
        device_serial = parts[0]
print(device_serial)

adb = ADB(serialno=device_serial)
print(adb.devices())
file_path = r"/data/local/tmp/"
b_time = time.strftime("%m-%d-%H:%M:%S")
file_name1 = b_time
file_name = os.path.join(file_path, file_name1) + ".mp4"
print(file_name)

device = connect_device("Android://127.0.0.1:5037/10ADB93277000SE?cap_method=javacap&touch_method=adb")

print(device)
if device:
    print("连接设备成功")
else:
    print("连接设备失败")

print("开始录制")


def operation():
    adb.shell(f"screenrecord {file_name}")
    pass


thread = threading.Thread(target=operation)
thread.start()

c = input(r"结束录制请输入'by':")

if c == "by":
    adb.shell("pkill screenrecord")
    print("已经结束录制")
    adb.pull(file_name, f"D:/work/data")
else:
    while True:
        c = input("输入错误请重新输入:")
        if c == 'by':
            adb.shell("pkill screenrecord")
            print("已经结束录制")
            adb.pull(file_name, f"D:/work/data/")
            break
        else:
            pass

以下是报错信息

D:\python\python.exe D:\work\coding\Python\ketang\luping.py 
[23:11:21][DEBUG]<airtest.core.android.adb> D:\python\lib\site-packages\airtest\core\android\static\adb\windows\adb.exe devices
执行成功
List of devices attached
10ADB93277000SE	device


10ADB93277000SE
[23:11:24][DEBUG]<airtest.core.android.adb> D:\python\lib\site-packages\airtest\core\android\static\adb\windows\adb.exe -P 5037 -s 10ADB93277000SE wait-for-device
[('10ADB93277000SE', 'device')]
/data/local/tmp/09-29-23:11:24.mp4
[23:11:24][DEBUG]<airtest.core.android.adb> D:\python\lib\site-packages\airtest\core\android\static\adb\windows\adb.exe -P 5037 -s 10ADB93277000SE shell getprop ro.build.version.sdk
[23:11:24][DEBUG]<airtest.core.android.adb> D:\python\lib\site-packages\airtest\core\android\static\adb\windows\adb.exe -s 10ADB93277000SE shell getprop ro.build.version.sdk
<airtest.core.android.android.Android object at 0x000001C6FCFEBFC8>
连接设备成功
开始录制
结束录制请输入'by':[23:11:24][DEBUG]<airtest.core.android.adb> D:\python\lib\site-packages\airtest\core\android\static\adb\windows\adb.exe -s 10ADB93277000SE shell screenrecord /data/local/tmp/09-29-23:11:24.mp4
by
[23:11:29][DEBUG]<airtest.core.android.adb> D:\python\lib\site-packages\airtest\core\android\static\adb\windows\adb.exe -s 10ADB93277000SE shell pkill screenrecord
[23:11:29][DEBUG]<airtest.core.android.adb> D:\python\lib\site-packages\airtest\core\android\static\adb\windows\adb.exe -s 10ADB93277000SE pull /data/local/tmp/09-29-23:11:24.mp4 D:/work/data
已经结束录制
Exception in thread Thread-9:
Traceback (most recent call last):
  File "D:\python\lib\site-packages\airtest\core\android\adb.py", line 374, in shell
    out = self.raw_shell(cmd)
  File "D:\python\lib\site-packages\airtest\core\android\adb.py", line 332, in raw_shell
    out = self.cmd(cmds, ensure_unicode=False)
  File "D:\python\lib\site-packages\airtest\core\android\adb.py", line 197, in cmd
    raise AdbError(stdout, stderr)
airtest.core.error.AdbError: stdout[b''] stderr[b'']

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
  File "D:\python\lib\threading.py", line 926, in _bootstrap_inner
    self.run()
  File "D:\python\lib\threading.py", line 870, in run
    self._target(*self._args, **self._kwargs)
  File "D:\work\coding\Python\ketang\luping.py", line 55, in operation
    adb.shell(f"screenrecord {file_name}")
  File "D:\python\lib\site-packages\airtest\core\android\adb.py", line 376, in shell
    raise AdbShellError(err.stdout, err.stderr)
airtest.core.error.AdbShellError: stdout[b''] stderr[b'']

Traceback (most recent call last):
  File "D:\work\coding\Python\ketang\luping.py", line 67, in <module>
    adb.pull(file_name, f"D:/work/data")
  File "D:\python\lib\site-packages\airtest\core\android\adb.py", line 456, in pull
    self.cmd(["pull", remote, local], ensure_unicode=False)
  File "D:\python\lib\site-packages\airtest\core\android\adb.py", line 197, in cmd
    raise AdbError(stdout, stderr)
airtest.core.error.AdbError: stdout[b"adb: error: cannot create 'D:/work/data\\09-29-23:11:24.mp4': No such file or directory\r\n"] stderr[b'']

进程已结束,退出代码1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值