模块与包

1 什么是模块?

一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀

2 为何要使用模块?

如果你对出python解释器然后重新进入,那么你之前定义的函数或者变量都将丢失,因此我们通常将程序写到文件中以便永久保存下来,需要时就通过python test.py方式去执行,此时test.py被称为脚本script

3 如何使用模块?

实例文件:spam.py ,文件名spam.py ,模块名spam

 print("from the spam.py")
money=1000
def read1():
print("spam-->read1-->money,money")
def read2():
print("spam-->read2-->")
read1()
def change():
global money
money=0
3.1.1 模块可以包含可执行的语句和函数的定义,这些语句的目的是初始化模块,它们只在模块名第一次遇到导入import语句时才执行
         python的优化手段是:第一次导入后就将模块名加载到内存了,后续的import语句仅是对已经加载大内存中的模块对象增加了一次引用,不会重新执行模块内的语句
import spam  #只在第一次导入时才执行spam.py内代码,
# 此时的显示效果是只打印一次“from the spam.py"
import spam
import spam
import spam 执行结果为:
from the spam.py

 3.1.2 每个模块都是一个独立的名称空间,定义在这个模块中的函数,把这个函数的名称空间当做全局名称空间。

         这样我们在编写自己的模块时,就不用担心我们在定义在自己模块中全局变量会在被导入时,与使用者的全局变量冲突
#测试一:money与spam.money 不冲突
#test.py
import spam
money=100
print(spam.money) 执行结果:
from the spam.py
1000

#测试二:read1与spam.read1 不冲突
#test.py
import spam
def read1():
print("read1")
spam.read1() 执行结果:
from the spam.py
spam-->read1-->money,money

  

#测试三:执行spam.change()操作的全局变量money仍然是spam中
#test.py
import spam
money=10
spam.change()
print(money) 执行结果:
from the spam.py
10
总结:导入模块会执行文件

 第一件事:创建名称空间,用来存放spam.py中定义的名字

 第二件事:基于刚刚创建的名称空间来执行spam.py

 第三件事:创建名字spam指向该名称空间,spam.名字的操作,都是以spam.py为准

  

3.1.3 为模块名起别名,相当于m1=1;m2=m1

import spam as sm
print(sm.money) 执行结果:
from the spam.py
1000

  

3.1.4 在一行导入多个模块

import sys,os,re

  

3.2 from ……import…..

3.2.1 对比import spam,会将源文件的名称空间“spam”带到当前名称空间时,使用时必须是spam.名字的方式。

而from语句相当于import。也会创建新的名称空间,但是将spam的名字直接导入到当前的名称空间中,在当前的名称空间中,直接使用名字就可以了

from spam import read1,read2

这样在当前位置直接使用read1和read2就好了,执行时,仍然以spam.py文件全局名称空间

#测试一:导入的函数read1,执行时仍然回到spam.py中寻找全局变量money
#test.py
from spam import read1
money=1000
read1() 执行结果
from the spam.py
spam-->read1-->money,money

  

#测试二:导入的函数read2,执行时需要调用read1(),仍然回到spam.py中找read()
#test.py
from spam import read2
read2() 执行结果
from the spam.py
spam-->read2-->
spam-->read1-->money,money  

如果当前有重名read1或者read2,那么会有覆盖效果

#测试三:导入的函数read1,会被当前位置定义的read1覆盖掉
#test.py
from spam import read1
def read1():
print("----->")
read1() 执行结果
from the spam.py
----->

需要特别强调的一点是:python中的变量赋值不是一种存储操作,而只是一种绑定关系

from spam import money,read1
money=100
print(money)
read1() 执行结果为:
from the spam.py
100
spam-->read1-->money,money

   

3.2.2 也支持as

form spam import read1 as read

  

3.2.3 支持导入多行

from spam import (read1,
read2,
money)

  

3.2.4 from spam import * 与__all__ * 控制来使用

在spam.py中新增一行

_all_=["money","read1"] #字符串形式

#test.py
from spam import * #不建议去用,避免重名
print(money)
print(read1) 执行结果
from the spam.py
1000
<function read1 at 0x02543390>

  

3.3 把模块当做脚本执行 

我们通过模块的全局变量__name__来看模块名

当做脚本运行:

__name__等于”__main__”

当做模块导入:

__name__

print(__name__)
#test.py
import spam 执行结果
spam

作用:用来控制.py文件在不同的应用场景下执行不同的逻辑

if __name__ == '__main__':
print("文件当做脚本去执行") 执行结果
文件当做脚本去执行

 

3.4 模块搜索路径

结模块的查找顺序是:内存中已经加载的模块->内置模块->sys.path路径中包含的模块

import spam #先找内存:sys.modules-----》再找内建-----》最后找sys.path

在初始化后,python程序可以修改sys.path 路径放到前面优先于标准库被加载

import sys
sys.path.append(r'F:\\python_fullstack_s4\\day35\\模块')
sys.path.insert(0,r'F:\\python_fullstack_s4\\day35\\模块') #排在前面的目录,优先被搜索

  

 

python—-模块与包1的更多相关文章

  1. Python/模块与包之模块

    Python/模块与包之模块 1.什么是模块? 模块就是py文件 2.为什么要用模块? 如果在解释器上进行编码,把解释器关闭之前写的文件就不存在了,如果使用模块的话就能永久保存在磁盘中. 3.如何使用 ...

  2. Python模块、包、异常、文件(案例)

    Python模块.包.异常.文件(案例) python.py #模块 # Python中的模块(Module),是一个Python文件,以.py文件结尾,包含了Python对象定义和Python语句, ...

  3. 【Python】解析Python模块与包

    模块 模块是非常简单的Python文件,单个Python文件就是一个模块,两个文件就是两个模块. import语句是用来导入模块或者从模块里导入特定的类或者函数.如前面我们用过的math模块,从而可以 ...

  4. python 模块和包深度学习理解

    python 模块和包 简单说相当于命名空间 1,python 模块        python模块就是一个文件,里面有函数,变量等 import 模块 模块.方法 from 模块 import fu ...

  5. (三)运用Python模块和包

    1 引言 为了能够在Python项目中高效地运用Python模块和包,我们需要进一步地来了解它们是如何在Python项目中进行定义.使用和工作的. 2 Python模块和包 Python模块和包的基本 ...

  6. Python模块04/包/logging日志

    Python模块04/包/logging日志 目录 Python模块04/包/logging日志 内容大纲 1.包 2.logging日志 3.今日总结 内容大纲 1.包 2.logging日志 1. ...

  7. Python模块和包

    模块和包是python组织代码的基本方式. 模块: python的每一个脚本文件都可称之为模块,模块的名称就是脚本的文件名.例如当我们写了一个test.py的脚本文件,则可以在同目录下的另外一个脚本m ...

  8. python模块与包的导入

    1. 模块与包的区别 模块,即module,一个包含python语句的.py文件就是一个模块!每个源代码文件都会自动成为模块!没有额外的语法用来声明模块. 包,又称模块包,即module packag ...

  9. python模块及包的导入

    一.模块 通常模块为一个文件,直接使用import来导入就好了.可以作为module的文件类型有".py".".pyo".".pyc".&q ...

  10. 简述Python模块和包

    我们常常会使用别人写的包,假如我们使用的是Python3.4版本,安装在windows的C盘根目录下,那么外部的包一般放在:C:\Python34\Lib\sit-packages下,此目录下有以.p ...

随机推荐

  1. Hibernate之三态

    1.瞬时态 瞬时态也成为临时态或者自由态,瞬时态的实例是new命令创建.开辟内存空间的对象,不存在持久化标识OID,尚未与Hibernate Session关联,在数据库中没有任何记录,失去引用将被G ...

  2. python web开发-flask中日志的使用

    Flask使用日志记录的方式: 初始化flask应用实例 在flask中使用logger,需要初始化一个flask的应用 app = Flask(__name__) 2. 调用logger 直接调用l ...

  3. 笔记:Struts2 拦截器

    配置拦截器 Struts.xml 配置文件中,使用<interceptor-/>来定义拦截器,有属性 name 表示拦截器的名称,class 表示拦截器的具体首先类,可以使用<par ...

  4. linux --> 获取系统启动时间

    获取系统启动时间 一.前言 时间对操作系统来说非常重要,从内核级到应用层,时间的表达方式及精度各部相同.linux内核里面用一个名为jiffes的常量来计算时间戳.应用层有time.getdaytim ...

  5. Java实现单向链表基本功能

    一.前言 最近在回顾数据结构与算法,有部分的算法题用到了栈的思想,说起栈又不得不说链表了.数组和链表都是线性存储结构的基础,栈和队列都是线性存储结构的应用- 本文主要讲解单链表的基础知识点,做一个简单 ...

  6. Python中协程的实现

    通过关键字yield,可以从生成器中产生值,并返回.我们可以将生成器作为一个生产者来使用. 在协程中,通过使用关键字yield,还可以让具有yield的程序接收值.此时函数作为消费者,消费我们传入(s ...

  7. python元类理解2

    恩,对元类理解又有新的收获,其实类似于装饰器,只不过装饰器是修饰函数,元类用来定制一个类. 代码如下,这是一个使用了函数做元类传递给类: input: def upper_attr(class_nam ...

  8. .NET Core初体验 在window上构建第一个app

    ASP.NET Core 是一个跨平台,高性能的开源框架,用于构建现代化的,基于云的互联网应用程序.使用 ASP.NET Core ,您可以: 构建Web应用程序和服务,IoT应用程序和移动后端. 在 ...

  9. 网络1712--c语言一二维数组作业总结

    1.成绩摆前头 1.1基本要求(1分) 按时交 - 有分 未交 - 0分 迟交一周以上 - 倒扣本次作业分数 抄袭 - 0分 泛泛而谈(最多七分) 1.2评分要点 PTA作业总结(4分) 同学代码互评 ...

  10. defaultdict使用及__missing__理解

    import collections import re WORD_RE = re.compile(r'\w+') index = collections.defaultdict(list) #用li ...