目录
  • 一、简单代码
  • 二、稍复杂的代码
  • 总结

一、简单代码

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

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持小闻网。

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。