在Windows下配置点击就能运行Python程序的bat批处理脚本

0,需求说明

在编写和调试程序时,一般我们会在集成编辑环境里写代码和运行,但如果程序比较完善需要快速运行,或者让同事在其他电脑上快速运行时,再打开IDE(Integrated Development Environment ,集成开发环境)运行就有些麻烦了,对方也不一定很熟练使用命令行进行运行,因此在Windows下要解决这个问题一般有两种思路:1,把程序编译为exe文件,就是一个小软件,和QQ等软件的运行方式基本无差别,通过鼠标点击运行;2,另外的做法是编写批处理文件,点击批处理文件就会按顺序执行命令行(在其他电脑运行是需要保证对方正确安装了编程/编译环境,例如是运行Python程序需要安装好Python、Java程序需要安装好JDK并配置好环境变量)。

Windows下的批处理文件后缀是.bat;点击该文件就可以执行。

.bat文件是可执行文件,由一系列命令构成,其中可以包含对其他程序的调用。

下面具体说明通过bat批处理文件实现点击执行Python代码。

1,编写Python程序

如果本身程序比较完备了,这步跳过,下面新建一个超经典的hello world作为例子,选定一个文件夹然后新建一个文本文件,写入print("hello world")。保存文件名为hellopy,把文件后缀从.txt改为.py

2,编写批处理脚本

同样新建文本文件,输入python hellopy.py。保存为helloshell,后缀是.bat。
然后点击helloshell.bat就可以看到黑色的命令行窗口一闪而过,这是因为运行后cmd会自动关闭,因此为了看效果可以考虑用time.sleep(10)或选择运行程序后新建一个文件以显示程序正确运行了,以采用sleep的方案为例,把hellopy.py中的代码改为:

import time
print("hello world")
time.sleep(5) 

time.sleep(5) 表示程序运行到这一行会休眠5秒。

完成上述步骤后有两个文件如图:


需要运行的Python程序和批处理文件

点击运行:


bat文件运行后的效果

4,点击运行jupyter notebook导出的程序

以上步骤已经实现了基础需求,继续让例子更有针对性,在数据科学实践中,大家喜欢用Jupyter notebook进行运行和调试,但是有些常规需求我们不想再打开notebook一个个cell点击运行,想之间点击一下就自动化处理excel,这个需求就改一下bat文件就好,首先把jupyter notebook中能够正常运行的程序导出为py文件,在工具栏的File->Download As->Python(.py) 下,例如以下代码,读取一个Excel,对Excel进行处理后把数据框(DataFrame)的数据保存到一个Excel里。

jupyter notebook 程序例子

File->Download As->Python(.py)中导出Python文件using2019fords.py,然后把bat文件中的内容更新为python using2019fords.py。点击运行就可以。

5,把bat文件放桌面

把bat移到桌面,运行更方便,程序和数据仍然在特定文件夹下,这时候可以直接写python d:/文件夹路径/python文件名.py,保存后运行就可以。

在桌面运行bat文件1

另外就是按照cmd的步骤写,先定位到目标文件夹下,然后是python 文件名.py
在桌面运行bat文件6

6,运行bat中传参数

一般比较推荐把参数写入Python程序里,但也可以在批处理文件中传参数。bat中的语法是python 文件名.py 参数1 参数2

对应的Python文件中接受参数的代码为(using2019fords.py仍为jupyter notebook中导出的文件):

# coding: utf-8
# In[1]:
import time
import pandas as pd
# In[2]:
import sys
print("当前运行脚本:", sys.argv[0])
print("运行时间:",time.localtime(time.time())) #

for i in range(1, len(sys.argv)): #有哪些参数
    print("参数{0}为:{1}".format(i, sys.argv[i])) #对参数进行处理

wp=r"J:\LinuxLearn\cixinliu\clickToRunBat"
adf=pd.read_excel(wp+"/hellodata.xlsx")
# In[7]:
adf.head(2)
# In[ ]:
#对读入的表进行逻辑处理
# In[4]:
adf['D']=adf["C"].apply(lambda x:x*2)
# In[6]:
adf.to_excel(wp+"/out_hellodata.xlsx")#输出

print("finish")
time.sleep(5) 

运行效果如下:


bat中传参例子

另外可能会遇到的需求是代码比较固定了,需要每天定时运行程序读取文件更新数据、发邮件等,定时运行的做法可以参考定时运行Python程序

Linux

用Linux的同学大部分都习惯于直接写命令行了,语法和Windows下的一致,首先定位到Python程序所在的目录下,然后用python maincode.py运行。
在Linux和Mac下的批处理文件文件后缀是.sh 。下面是一个运行的具体例子,Python程序仍然用前面说的hellopy.py

Ubuntu下运行sh文件例子

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,222评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,455评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,720评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,568评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,696评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,879评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,028评论 3 409
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,773评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,220评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,550评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,697评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,360评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,002评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,782评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,010评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,433评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,587评论 2 350

推荐阅读更多精彩内容