python如何启动cmd批处理文件!

python如何启动cmd批处理文件!

这篇文章主要介绍了python如何启动cmd批处理文件问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教。

一、简单代码

直接上代码,理解起来还是比较简单,os的简单,控制力比较小,subprocess的可以将相应的cmd输出获取到,便于进一步分析运行结果

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#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文件:

1
2
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
1
2
3
4
@echo off
echo 显示命令行参数 %1%
set /p ver=请输入版本:
echo 输入的版本为:%ver%

此文件含有两种参数输入:

  • 其一是命令行参数
  • 其二是键盘输入参数

要求用户在执行过程中输入版本号,若是用之前的代码,

你会发现程序总是没有输入提示,而当你输入完成后,提示及结果会一并出来

究其原因是由于读出来的数据readline()是以回车换行为标志的

提示语句没有提示换行,因此直到操作完成后才能读取到提示文字

明白了原因:

改进的方法也就出来了,每次只读取单个字符并显示,直到读不到为止,print这样的函数默认换行并且立即输出,必须加参数让其按文件格式打印.另外,之前的数据转换是一次性转换,一般不会出现异常,单个字节读取对于中文字而言转换会出异常,必须专门进行处理

以下为修改的代码:

  • sam.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
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)

总结

以上为个人经验,希望能给大家一个参考。

 

学习资料见知识星球。

以上就是今天要分享的技巧,你学会了吗?若有什么问题,欢迎在下方留言。

快来试试吧,小琥 my21ke007。获取 1000个免费 Excel模板福利​​​​!

更多技巧, www.excelbook.cn

欢迎 加入 零售创新 知识星球,知识星球主要以数据分析、报告分享、数据工具讨论为主;

大型电视艺术教学片《汉字宫》!

你将获得:

1、价值上万元的专业的PPT报告模板。

2、专业案例分析和解读笔记。

3、实用的Excel、Word、PPT技巧。

4、VIP讨论群,共享资源。

5、优惠的会员商品。

6、一次付费只需99元,即可下载本站文章涉及的文件和软件。

文章版权声明 1、本网站名称:Excelbook
2、本站永久网址:http://www.excelbook.cn
3、本网站的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,请联系站长王小琥进行删除处理。
4、本站一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
5、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报。
6、本站资源大多存储在云盘,如发现链接失效,请联系我们我们会第一时间更新。

THE END
分享
二维码
< <上一篇
下一篇>>