一、简单代码
直接上代码,理解起来还是比较简单,os的简单,控制力比较小,subprocess的可以将相应的cmd输出获取到,便于进一步分析运行结果
#import os
#os.system("c:\\sam.bat")
import subprocess
cmd = 'cmd.exe c:\\sam.bat'
p = subprocess.Popen("cmd.exe /c" + "c:\\sam.bat abc", stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
curline = p.stdout.readline()
while(curline != b''):
print(curline)
curline = p.stdout.readline()
p.wait()
print(p.returncode)
附上sam.bat文件:
echo Hello world!
echo show %1%
b'\r\n'
b'c:\\Python34>echo Hello world! \r\n'
b'Hello world!\r\n'
b'\r\n'
b'c:\\Python34>echo show abc \r\n'
b'show abc\r\n'
0
二、稍复杂的代码
对于普通的应用以上的代码已经足够,若是批处理文件比较特别,比如启动的批处理带有键盘输入参数,这样上面的代码就会出现问题,如下的批处理文件:
sam.bat
@echo off
echo 显示命令行参数 %1%
set /p ver=请输入版本:
echo 输入的版本为:%ver%
此文件含有两种参数输入,其一是命令行参数,其二是键盘输入参数,要求用户在执行过程中输入版本号,若是用之前的代码,你会发现程序总是没有输入提示,而当你输入完成后,提示及结果会一并出来,究其原因是由于读出来的数据readline()是以回车换行为标志的,提示语句没有提示换行,因此直到操作完成后才能读取到提示文字。
明白了原因,改进的方法也就出来了,每次只读取单个字符并显示,直到读不到为止,print这样的函数默认换行并且立即输出,必须加参数让其按文件格式打印.另外,之前的数据转换是一次性转换,一般不会出现异常,单个字节读取对于中文字而言转换会出异常,必须专门进行处理
以下为修改的代码:
sam.py
import subprocess
cmd = 'cmd.exe c:\\sam.bat'
p = subprocess.Popen("cmd.exe /c" + "c:\\sam.bat abc", stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
byte_data = p.stdout.read(1)
word_data = b''
while(byte_data != b''):
word_data += byte_data
try:
showdata = word_data.decode('gb2312')
print(showdata, end="", flush=True)
word_data = b''
except Exception as e:
#print(e)
a=0
byte_data = p.stdout.read(1)
p.wait()
print(p.returncode)