博客
关于我
__name__
阅读量:496 次
发布时间:2019-03-07

本文共 1528 字,大约阅读时间需要 5 分钟。

关于Python中的__name__变量解析scription.chars

In Python, the __name__ variable is a built-in variable that identifies the name of the module in which it is defined. This variable is particularly useful for debugging and understanding the structure of your program.

To demonstrate how __name__ works, let's look at some examples:

示例1: demo1.py

This script defines a function called printName(), and when executed directly, it will show the current module's name.

这样的情况可能,请看下文。
def printName():    print("Example1's __name__ is: " + __name__)

示例2: demo2.py

In this file, we import the printName function from demo1.py and execute it within the context of demo2.py. When running this script, the output will differ from the previous example.

import demo1if __name__ == '__main__':    printName()    print("Example2's __name__ is: " + __name__)

运行结果分析

运行上述脚本时,你会看到以下输出:

Example1's __name__ is: demo1

Example2's __name__ is: __main__

这个结果揭示了两件重要事情:

1. 当你在当前文件直接执行代码时,__name__变量将显示当前文件的名称。2. 当你从另一个文件导入函数并在该文件中执行时,__name__变量将显示__main__,这符合Python对模块执行行为的设计原则。

在PyCharm中如何运行

In PyCharm, you can right-click on your Python file (e.g., demo2.py) and select "Run demo2.py" from the context menu. This will execute the script and display the results in the console.

理解模块名称

Python使用模块化设计来组织代码,其中每个模块可以独立地包含功能。每个模块都有自己的__name__变量,其值取决于该模块如何被调用:

  • 主模块:当你直接运行一个文件时,该文件被称为"主模块"。在这种情况下,__name__变量将显示文件名(不带.py扩展名)。
  • 导入模块:当你从一个文件中导入函数或代码片段到主模块时,该文件被称为导入模块。在这种情况下,__name__变量将显示文件名(不带.py扩展名)。

总结

通过以上示例,我们可以清晰地看到__name__变量在不同情况下的行为。理解这一点对于调试和优化你的Python程序是非常重要的。

转载地址:http://egncz.baihongyu.com/

你可能感兴趣的文章
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 参数--lock-tables浅析
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump 导出数据库中每张表的前n条
查看>>
mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
查看>>
Mysqldump参数大全(参数来源于mysql5.5.19源码)
查看>>
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>
mysqldump数据库备份无法进行操作只能查询 --single-transaction
查看>>
mysqldump的一些用法
查看>>
mysqli
查看>>
MySQLIntegrityConstraintViolationException异常处理
查看>>
mysqlreport分析工具详解
查看>>
MySQLSyntaxErrorException: Unknown error 1146和SQLSyntaxErrorException: Unknown error 1146
查看>>
Mysql_Postgresql中_geometry数据操作_st_astext_GeomFromEWKT函数_在java中转换geometry的16进制数据---PostgreSQL工作笔记007
查看>>
mysql_real_connect 参数注意
查看>>
mysql_secure_installation初始化数据库报Access denied
查看>>
MySQL_西安11月销售昨日未上架的产品_20161212
查看>>
Mysql——深入浅出InnoDB底层原理
查看>>
MySQL“被动”性能优化汇总
查看>>