模块概念

在Python中,一个.py文件就称之为一个模块(Module)。使用模块组织代码,最大的好处是大大提高了代码的可维护性

模块一共三种:python标准库、第三方模块、应用程序自定义模块。

相同名字的函数和变量完全可以分别存在不同的模块中,因此,我们自己在编写模块时,不必考虑名字会与其他模块冲突。但是也要注意,尽量不要与内置函数名字冲突。

模块导入

import语句

1 import module1[, module2[,... moduleN]

import一个模块的实质就是把这个python文件从头到尾执行一遍

import模块的查找模块的顺序
1、先从当前目录下找
2、当前目录下找不到的话,在从sys.path的路径找
从上面两个目录都找不到,那就报错

每次import的时候,都会相应的开辟内存空间存放被import的内容,但是与调用import的文件开辟的内存空间相互独立。例如import foo.py在新建的名称空间里执行源文件(foo.py)代码时,所有对全局名称空间的引用或修改,都是以foo.py为准。

注意:

一个模块可以在当前位置import多次,但是只有第一次导入会执行内容,其他的都为引用内存

更改调用名称:将logging更改为log

1 import logging as log
2 log.critical("www")

from...import语句

1 from modname import name1[, name2[, ... nameN]]

这个声明不会把整个modulename模块导入到当前的命名空间中,只会将它里面的name1或name2单个引入到执行这个声明的模块的全局符号表。

moudel_name.py

# -*- coding:utf-8 -*-
print("This is module_name.py") name = 'Hello' def hello():
print("Hello")

module_test04.py

# -*- coding:utf-8 -*-
import module_name def a():
module_name.hello()
print("fun a") def b():
module_name.hello()
print("fun b") a()
b()
运行结果:
E:\PythonImport>python module_test04.py
This is module_name.py
Hello
fun a
Hello
fun b

多个函数需要重复调用同一个模块的同一个方法,每次调用需要重复查找模块。所以可以做以下优化:

module_test05.py

# -*- coding:utf-8 -*-
from module_name import hello def a():
hello()
print("fun a") def b():
hello()
print("fun b") a()
b()
运行结果:
E:\PythonImport>python module_test04.py
This is module_name.py
Hello
fun a
Hello
fun b

可以使用"from module_name import hello"进行优化,减少了查找的过程。

包的调用

为了避免模块名冲突,Python又引入了按目录来组织模块的方法,称为包(Package)。

每一个包目录下面都会有一个__init__.py的文件,这个文件是必须存在的,否则,Python就把这个目录当成普通目录(文件夹),而不是一个包。__init__.py可以是空文件,也可以有Python代码,因为__init__.py本身就是一个模块,而它的模块名就是对应包的名字。调用包就是执行包下的__init__.py文件。

跨包调用(当前目录下有modulepack1包):

1 from modulepack1[.modulepack2] import module

如果当前目录下能够找到要调用的包,可以直接from包import模块,如果当前目录找不到要调用的包,需要向sys.path添加包的所在绝对路径。

import一个包名,就等于执行了这个包下的__init__文件。

示例:

在nod1里import  hello是找不到的,需要手动添加包路径,如果找到那是因为pycharm给加了不必要的路径,以命令行执行为准。

1 import sys,os
2 BASE_DIR=os.path.dirname(os.path.dirname(os.path.abspath(__file__)))  #__file__获取执行文件相对路径,整行为取上一级的上一级目录
3 sys.path.append(BASE_DIR)  #添加路径
4 import hello
5 hello.hello1()

将包设置为程序代码的根目录

模块调用测试

1 if __name__=='__main__':  #__name__方法判断
2 print('ok')

在一个py模块直接执行print(__name__)会输出__main__,表示当前这个文件属于执行文件,如果从其他的py模块中导入一个py模块,执行被导入的py模块中的print(__name__)会输出被导入的模块的模块名称,那么if判断就不会成功,所以导入的时候不会执行判断内的代码。

主要用在调试功能,即一个模块被调用的时候不执行内容,而自己调试模块的时候可以顺利的执行模块内容。

内建函数

可以通过 "print(dir(__builtins__))" 查看Python中的内建函数

非内建函数需要使用"import"导入。Python中的模块文件在"安装路径\Python\Python35\Lib"目录下。

最新文章

  1. 仿iphone日历插件(beta)
  2. 逻辑运算符——逻辑与&&、逻辑或||
  3. R12月末关帐的异常检查和处理
  4. WCF分布式开发步步为赢(3)WCF服务元数据交换、配置及编程开发
  5. guidelines for contributing Hearthstone-Deck-Tracker
  6. 使用dev http client调试restful API开发
  7. ibatis.net demo
  8. Data Abstraction
  9. 保存BASE64编码图片
  10. javascript每日一练(十四)——弹性运动
  11. SQL注入相关的知识【Mysql为例子】
  12. SDRAM操作说明
  13. 巧用php中的array_filter()函数去掉多维空值
  14. vscode常用快捷键
  15. XPath定位时,使用文本的方法小技巧。
  16. Unity3D动态生成多边形
  17. Servlet下载文件迅雷不支持问题真相之一
  18. Java并发系列
  19. 原来java中也有类似goto语句的标签啊--java label标签
  20. C++11中std::unordered_map的使用

热门文章

  1. 洛谷P3703 树点涂色
  2. 斯坦福大学公开课机器学习:machine learning system design | data for machine learning(数据量很大时,学习算法表现比较好的原理)
  3. 在Linux中复制文件夹下的全部文件到另外文件夹
  4. 计算机基础:计算机网络-socket编程
  5. 高级组件——表格JTable
  6. 《玩转Django2.0》读书笔记-探究视图
  7. python 计算机发展史,线程Process使用 for循环创建 2种传参方式 jion方法 __main__的解释
  8. sql关联更新
  9. eDEX-UI
  10. com.netflix.client.ClientException: Load balancer does not have available server for client xxxx