一、简单代码
直接上代码,理解起来还是比较简单,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)
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。