Python主程序执行模块的实现是怎样,代码是什么
Admin 2022-09-08 群英技术资讯 476 次浏览
前言:
这个先来创建一个模块,名称为christmastree,在该模块中,首先定义一个全局变量,然后创建一个名称为fun_christmastree()的函数,最后再通过print()函数输出一写内容。
代码如下:
printree = "我是小菜鸡" # 定义全局变量”小菜鸡“ def fun_christmastree(): # 定义函数 """功能: 一个梦 :return 无返回值 """ printree = "新星计划,颁奖...我获奖了@^。^@" # 定义局部变量 print(printree) # 输出局部变量 # ********************函数体外*********************** # print("\n夜深了……\n") print("===============开始做梦……===============") fun_christmastree() # 调用函数 print("===============开始做梦……===============") printree = "原来是一场梦," + printree + "-_-" print(printree) # 输出全局变量
在与christmastree模块同级的内容介绍下,创建一个名称为main.py的文件,在该文件中,导入christmastree模块,再通过print()语句输出模块中的全局变量printree的值,
代码如下:
import christmastree print("全局变量的值为:", christmastree.printree)
运行上面代码,将显示如图所示的内容:
从上图所示的运行结果可以看出,导入模块后,不仅输出了全局变量的值,而且模块中原有的测试代码也被执行了。这个结果显然不是我们想要的。那么如何只输出全局变量的值呢?实际上,可以在模块中,将原本直接执行的测试代码放在一个if语句中。
因此,可以将模块christmastree的代码修改为以下内容:
printree = "我是小菜鸡" # 定义全局变量”小菜鸡“ def fun_christmastree(): # 定义函数 """功能: 一个梦 :return 无返回值 """ printree = "新星计划,颁奖...我获奖了@^。^@" # 定义局部变量 print(printree) # 输出局部变量 # ********************判断是否以主程序的形式运行*********************** # if __name__ == "__main__": print("\n夜深了……\n") print("===============开始做梦……===============") fun_christmastree() # 调用函数 print("===============梦醒了……===============") printree = "原来是一场梦," + printree + "-_-" print(printree) # 输出全局变量
再次执行导入模块main.py 文件,将显示以下如图所示的结果,从执行结果中可以看出测试代码并没有被执行。
此时,如果执行christmastree.py文件,将显示如下图所示的结果:
说明: 在每个模块的定义中都包括一个记录模块名称的变量__name__,程序可以检查该变量,以确定它们在那个模块中执行。如果一个模块不是被导入到其他程序中执行,那么它可能在解释器的顶级模块中执行。顶级模块的__name__变量的值为__main__。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
Python中日期格式化是非常常见的操作,Python 中能用很多方式处理日期和时间,转换日期格式是一个常见的功能。Python 提供了一个 time
这篇文章主要为大家介绍了PyTorch搭建LSTM实现时间序列负荷预测,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
pytest提供了许多运行命令以供定制化运行某一类测试用例或者某个测试用例等,下面这篇文章主要给大家介绍了关于pytest用例间参数传递的两种实现方式,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
Django程序做优化还是很有必要的,在一定程度上能提高性能,但是要注意千万别过度性能优化。对此,下面小编就给大家分享一下Django程序的基本技巧,感兴趣的朋友可以参考。
Spark是基于内存计算的大数据并行计算框架,比MapReduce计算框架具有更高的实时性,同时具有高效容错性和可伸缩性,在学习Spark操作之前,首先介绍Spark运行架构和基本运行流程...
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008