python再学习4 启动cmd批处理文件

一、简单代码

直接上代码,理解起来还是比较简单,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)





你可能感兴趣的:(python)