Python标准库系列之模块默认全局变量

简介:

当我们创建了一个自己写的模块后,那么这个模块本身就自带了好几个全局变量,这些全局变量在每个文件中都存在。

查看当前py文件的全局变量

1
2
3
[root@ansheng ~] # echo 'print(vars())' > scripts.py      
[root@ansheng ~] # python scripts.py 
{ '__builtins__' : <module  '__builtin__'  (built- in )>,  '__name__' '__main__' '__file__' 'scripts.py' '__doc__' : None,  '__package__' : None}

默认全局变量

变量名 说明
__doc__ py文件的注释,是对文件的注释
__file__ 获取当前文件路径
__package__ 返回导入的文件所在包,用.分隔,如果是当前文件则返回None
__cached__ 返回导入的其他文件pyc文件路径,当前文件返回None
_name_ 如果是主文件则返回__main__ 否则等于模块名

没有列出来的就是没必要许了解的

实例

返回scripts文件的注释及文件路径

1
2
3
4
5
6
7
[root@ansheng ~] # cat scripts.py 
#!/usr/bin/env pyton# 文件的注释顶格写
"" "  Python file comments " ""
# 输出文件注释
print( "comments" ,__doc__)
# 输出文件路径
print( "file path" ,__file__)

执行脚本

1
2
3
4
[root@ansheng ~] # python scripts.py 
( 'comments' '  Python file comments ' )
 
( 'file path' 'scripts.py' )

__name__函数的应用

查看当前目录下面的文件及文件内容

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
[root@ansheng ~] # ls -l
total 8
drwxr-xr-x 2 root root 4096 May 24 21:36 lib
-rw-r--r-- 1 root root   80 May 24 21:37 scripts.py
[root@ansheng ~] # ls -l lib/
total 12
-rwxr-xr-x 1 root root  54 May 24 21:36 f1.py
-rw-r--r-- 1 root root   0 May 24 21:34 __init__.py
[root@ansheng ~] # cat lib/f1.py
#!/usr/bin/env python
def  echo ():
  print( "lib/f1.py" )
[root@ansheng ~] # cat scripts.py 
#!/usr/bin/env pyton
from lib  import  f1
 
if  __name__ ==  "__main__" :
   f1. echo ()
执行`scripts.py`脚本,脚本会调用`lib/f1.py`文件,而`lib/f1.py`文件会输出`lib/f1.py`,所以执行`scripts.py`文件的时候自然也会输出`lib/f1.py`

```bash
[root@ansheng ~]# python scripts.py 
# 正如我们看到的,会输出下面的内容
lib/f1.py

这是我们再创建一个scripts1.py文件

1
[root@ansheng ~] # touch scripts1.py

scripts1.py文件内容如下

1
2
[root@ansheng ~] # cat scripts1.py 
#!/usr/bin/env pytonimport scripts

文件创建好后执行他,我们会发现什么也没有输出

[root@ansheng ~]# python scripts1.py

然后我们把scripts.py脚本文件内容改为如下

[root@ansheng ~]# cat scripts.py#!/usr/bin/env pytonfrom lib import f1
f1.echo()

再次执行scripts1.py脚本这是就会输出lib/f1.py

[root@ansheng ~]# python scripts1.py 
lib/f1.py

为什么会出现上面的情况呢?

因为原来的scripts.py文件加了if判断,其意思就是说如果__name__的值等于"__main__",那么我就执行f1.echo()方法,否则就什么也不做,当scripts.py文件被我们直接执行的时候的__name__返回结果是"__main__",如果被别的文件调用了,那么__name__返回的结果是"scripts"

自动把当前目录下面的bin目录添加到python的PATH变量中

目录结构及脚本内容如下

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
[root@ansheng ~] # tree /tmp/
/tmp/
├── bin
│   ├── f1.py
│   └── __init__.py
└── scripts.py
 
1 directory, 3 files
[root@ansheng ~] # cat /tmp/scripts.py 
#!/usr/bin/env pyton
import  os
import  sys
 
path = os.path. dirname (__file__)
mod_path = os.path. join (path, "bin" )
 
sys.path.append(mod_path)
for  in  sys.path:
     print(n)

执行结果

1
2
3
4
5
6
7
8
9
10
11
12
13
[root@ansheng ~] # python /tmp/scripts.py 
/tmp
/usr/lib64/python26 .zip
/usr/lib64/python2 .6
/usr/lib64/python2 .6 /plat-linux2
/usr/lib64/python2 .6 /lib-tk
/usr/lib64/python2 .6 /lib-old
/usr/lib64/python2 .6 /lib-dynload
/usr/lib64/python2 .6 /site-packages
/usr/lib64/python2 .6 /site-packages/gtk-2 .0
/usr/lib/python2 .6 /site-packages
/usr/lib/python2 .6 /site-packages/setuptools-0 .6c11-py2.6.egg-info
/tmp/bin

This site is open source. Improve this page.











本文转自 Edenwy  51CTO博客,原文链接:http://blog.51cto.com/edeny/2089744,如需转载请自行联系原作者
目录
相关文章
|
13天前
|
存储 缓存 JavaScript
python实战篇:利用request库打造自己的翻译接口
python实战篇:利用request库打造自己的翻译接口
26 1
python实战篇:利用request库打造自己的翻译接口
|
17天前
|
Python
【python】python跨文件使用全局变量
【python】python跨文件使用全局变量
|
17天前
|
存储 开发者 Python
Python中的collections模块与UserDict:用户自定义字典详解
【4月更文挑战第2天】在Python中,`collections.UserDict`是用于创建自定义字典行为的基类,它提供了一个可扩展的接口。通过继承`UserDict`,可以轻松添加或修改字典功能,如在`__init__`和`__setitem__`等方法中插入自定义逻辑。使用`UserDict`有助于保持代码可读性和可维护性,而不是直接继承内置的`dict`。例如,可以创建一个`LoggingDict`类,在设置键值对时记录操作。这样,开发者可以根据具体需求定制字典行为,同时保持对字典内部管理的抽象。
|
19天前
|
存储 缓存 算法
Python中collections模块的deque双端队列:深入解析与应用
在Python的`collections`模块中,`deque`(双端队列)是一个线程安全、快速添加和删除元素的双端队列数据类型。它支持从队列的两端添加和弹出元素,提供了比列表更高的效率,特别是在处理大型数据集时。本文将详细解析`deque`的原理、使用方法以及它在各种场景中的应用。
|
3天前
|
JSON API 数据格式
python的request库如何拿到json的返回值
python的request库如何拿到json的返回值
6 0
|
4天前
|
Python
python学习14-模块与包
python学习14-模块与包
|
6天前
|
SQL 关系型数据库 数据库
Python中SQLite数据库操作详解:利用sqlite3模块
【4月更文挑战第13天】在Python编程中,SQLite数据库是一个轻量级的关系型数据库管理系统,它包含在一个单一的文件内,不需要一个单独的服务器进程或操作系统级别的配置。由于其简单易用和高效性,SQLite经常作为应用程序的本地数据库解决方案。Python的内置sqlite3模块提供了与SQLite数据库交互的接口,使得在Python中操作SQLite数据库变得非常容易。
|
7天前
|
开发者 Python
Python中使用`requests`库进行文件上传与下载的技术详解
【4月更文挑战第12天】在Python的网络编程中,文件上传和下载是常见的需求。`requests`库作为一个强大且易用的HTTP客户端,为我们提供了简便的文件上传和下载功能。本文将详细介绍如何在Python中使用`requests`库进行文件上传和下载。
|
7天前
|
安全 API 开发者
Python中使用`requests`库进行请求头与自定义参数设置的技术详解
【4月更文挑战第12天】在Python中,`requests`库是一个强大且灵活的HTTP客户端,用于发送所有类型的HTTP请求。在发送请求时,我们经常需要设置请求头和自定义参数来满足不同的需求。本文将详细探讨如何在Python中使用`requests`库进行请求头和自定义参数的设置。
|
11天前
|
索引 Python
「Python系列」Python operator模块、math模块
Python的`operator`模块提供了一系列内置的操作符函数,这些函数对应于Python语言中的内建操作符。使用`operator`模块可以使代码更加清晰和易读,同时也能提高性能,因为它通常比使用Python内建操作符更快。
27 0

热门文章

最新文章