我自己安装了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