python使用subprocess.Popen运行bat脚本时报不支持输入重新定向错误分析

大图请右击在新标签页打开

Popen默认shell参数为False:


1
1

为True时默认使用 COMSPEC 环境变量指定的程序为shell:


2
2

在Windows上默认为cmd:


3
3

args参数为命令字符串时,因为dir是cmd的内建命令,需要指定shell=True:
例如:


4
4

而timeout,ping等都是独立的exe,可以不需要cmd:


5
5

args参数是文件路径形式时:


6
6

底层是调用了Windows的API,如下:


python使用subprocess.Popen运行bat脚本时报不支持输入重新定向错误分析_第1张图片
7

调试:


python使用subprocess.Popen运行bat脚本时报不支持输入重新定向错误分析_第2张图片
8

测试:


python使用subprocess.Popen运行bat脚本时报不支持输入重新定向错误分析_第3张图片
11

从调试结果以及测试来看,对于bat文件,可以不写lpApplicationName参数,Windows会自动使用cmd来运行(使用vbs文件测试返回错误:不是正确的win32程序,要指定lpApplicationName为cscript.exe才行,可能只有bat才有这个特权了)。

输入重定向的问题:
Popen是用创建子进程的方式来执行的,而timeout.exe在暂停时,可接受用户按键来终止,这个时候会需要输入,但是Popen给子进程的stdin只有


10
10

并不能让timeout重定向到用户输入上,所以出错。

解决的方法有很多,最简单的替换掉timeout语句为ping -w xxx 127.0.0.1 或者直接由python来接管timeout。

你可能感兴趣的:(python使用subprocess.Popen运行bat脚本时报不支持输入重新定向错误分析)