一、模块(Module)



1、模块的作用

     在交互模式下输出的变量和函数定义,一旦终端重新启动后,这些定义就都不存在了,为了持久保存这些变量、函数等的定义,Python中引入了模块(Module)的概念。

一个Python模块事实上就是一个脚本文件,具有后缀“.py”,比如 hello.py 就是一个模块文件名称。和普通文件一样能够被永久保存在本地存储磁盘中。


2、模块的内容
     Python模块中存放的是一些程序代码,比如,变量定义、函数定义或是代码语句。

以下是hello.py模块的内容。当中有一个变量 a,一个函数 fun()。和一个打印语句。

# -*- coding:UTF-8 -*-
#! /usr/bin/python3
a = [1, 2, 3]
def fun():
return 'fun()'
print('hello', fun(), a)
     这里介绍一个模块属性 __name__ ,该属性存储了当前模块的名称。比方,上面的 hello.py 其__name__就是 'hello.py'

3、模块的使用
     (1)第一种方式时将模块当做脚本运行。模块中的代码语句会得到运行
wuhui@wuhui-H55M-S2H:~/Desktop$ python3 hello.py
hello fun() [1, 2, 3]
     (2)另外一种方式时将模块导入。然后使用导入模块中定义的变量、函数等
>>> import hello
>>> hello.a
[1, 2, 3]
>>> hello.fun()
'fun()'

使用"import module"导入模块方式时,被导入模块不能带后缀;使用导入模块中定义的变量、函数时。必须使用模块名作为前缀,如"hello.a"而不是直接使用"a"。假设感觉这样麻烦的。能够使用以下的方式。将模块中所有的定义信息所有导入。

>>> from hello import *
>>> a
[1, 2, 3]
>>> fun()
'fun()'

4、模块的相关信息
     每一个模块都有自己的定义信息。包含变量、函数等以及一些“与生俱来”的内建变量,这些能够通过Python内建函数 dir() 来查看。

直接在终端下输出dir(),输出当前环境下的变量名
>>> dir()
['__builtins__', '__doc__', '__loader__', '__name__', '__package__', '__spec__']
导入上面的 hello.py 模块后,使用dir()查看。不仅输出了默认的的变量名。还输出了hello.py中我定义的变量a和函数fun的名称

>>> import hello
>>> dir(hello)
['__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__', '__package__', '__spec__', 'a', 'fun']
输出模块名
>>> print(hello.__name__)

hello


5、模块的搜索路径
     当导入模块时,Python依照一定的搜索顺序在指定的文件夹下搜索模块,假设找到则导入模块,否则会引发异常。比如,运行 “import hello”导入hello.py模块时,Python解释器首先依据模块名搜索内建模块。假设没有找到,则会去 sys.path 变量所列出的文件夹下搜索,sys.path的默认文件夹例如以下:
     (1)输入脚本所在文件夹(或当前文件夹,假设没有指定导入脚本,如 import ×)
     (2)环境变量 PYTHONPATH 所指定的文件夹(这个与系统环境变量中的PATH语法同样)
     (3)安装的文件夹(默认)
    假设导入的脚本是一个符号连接(Windows上的快捷方式),搜索文件夹是符号链接所连接的原始文件所在文件夹,而非符号连接所在文件夹。在Python解释器初始化之后,能够在程序中改动 sys.path


二、包(Package)

1、包的作用
     简言之,包就是一个容器,用来存放其它的模块和包。
     假设你之前接触过其它语言。相信包的概念应该不会陌生,其作用和 C++/C#中的namespace相似。与java中的包相似。Python中提出包的概念是为了方便不同模块的组织。当一个项目较大时,编写的模块数量众多并且是由不同成员编写的,这时候就难免会出现模块名、变量名、函数名、类名等重名的情况。尽管能够在名称前加前缀来区分,但这样的做法始终不是非常好。没有将模块的组织结构体现出来。使用包组织模块,就能够通过
"A.B"的方式来引用模块。其结构类似与树状,非常清楚。以下是一个包的结构:
PkgA/                         # 顶层包
__init__.py # 初始化 PkgA
PkgB/ # PkgA 的子包 PkgB
__init__.py # 初始化 PkgB
module1.py
module2.py
PkgC/ # PkgA 的子包 PkgC
__init__.py # 初始化 PkgC
module1.py
module2.py
    在包PkgA以下出现了同名的模块 module1.py和 module2.py 。通过加入子包 PkgB和 PkgC将其区分。


2、包的使用 —— 导入模块、变量、函数、类
     PkgB 以下的 module1.py 文件内容例如以下:
def say():
print(’hello')
    如今假设须要使用 PkgB下module1.py中定义的函数 say(),能够採用下列方式(导入变量、类方法一样):
# 方式一:导入函数所在模块
>>> import PkgA.PkgB.module1
>>> PkgA.PkgB.module1.say()
hello
# 方式二:从包 PkgA.PkgB 中导入函数所在模块
>>> from PkgA.PkgB import module1
>>> module1.say()
hello
# 方式三:从模块中导入函数
>>> from PkgA.PkgB.module1 import say
>>> say()
hello
     注意:使用 “import item” 导入时。“item”必须是一个包或模块。而且假设要引用item中定义的变量、函数或类,须要加上“item”这一前缀。

     方式一,比較繁琐;方式三。easy产生同名;推荐使用方式二。假设导入的模块中没有同名的函数 say() 。那么使用方式三会简洁很多。可是假设导入的模块或当前文件里已经定义了say。而你又须要使用模块module1中的函数say()那么就仅仅能使用方式二了,通过前缀区分,比如以下代码:
>>> from PkgA.PkgB import module1
>>> module1.say()
hello
>>> def say():
... print('world')
...
>>> say()
world
>>> module1.say()
hello

3、包的相关信息
     包以下有一个名为 "__init__.py" 的文件,存在该文件时,Python会将文件夹当做一个包来看待(只是好像没有也行,这里尚不清楚。知道的请留言补充). __init__.py 为一个空文件时没什么问题的,只是__init__.py 里面也能够存放初始化代码和变量
__all__。当导入当前包以下的模块或其它包时,首先当前包中的__init__.py 中的可运行代码会被运行,紧接着导入的模块中的可运行代码也会被运行。因为包或模块仅仅会被导入一次(即使再次使用import导入也无效果),因此这些可运行代码仅仅会被运行一次。

     另一个值得注意的就是__all__变量,该变量能够为空。当__init__中没有定义__all__变量时,"import package import *"仅仅导入package。而不导入不论什么模块。假设__init__定义了__all__变量,定运行"import package
import *"时,仅仅导入变量__all__中的定义的模块,而其它模块则不会被导入。这样能够防止"import *"的将全部模块导入导致载入缓慢和命名空间的污染。拿前面的代码举个样例:
# __init__.py中没有定义__all__时
from PkgA.PkgB import * # 只导入包 PkgB
# __init__.py 中定义 __all__ = ['module1']
from PkgA.PkgB import * # 只导入PkgB包中的模块 module1,而模块 module2则不会被导入
4、包的相对路径
     导入包时出了使用绝对路径。如 "from PkgA.PkgB
import module1" 外,还能够使用相对路径,"."表示当前包。“..”表示上一级包。

拿前面的代码举个样例。假设想在 PkgA.PkgC.module1中使用 PkgA.PkgB.module2中的函数 say(),能够这么写:


from ..PkgB from module2    
     # 这里的"..PkgB"就相当于"PkgA.PkgB"

4. 包的搜索路径

     当导入包时,Python会在sys.path 指定的文件夹下搜索,前面提到的sys.path默认文件夹例如以下,你也能够在程序中改动sys.path的值。
     (1)输入脚本所在文件夹(或当前文件夹,假设没有指定导入脚本,如 import ×)

     (2)环境变量 PYTHONPATH 所指定的文件夹(这个与系统环境变量中的PATH语法同样)
     (3)安装的文件夹(默认)

參考:

[1] The Python Tutorial https://docs.python.org/3/tutorial/modules.htm

版权声明:本文博客原创文章,博客,未经同意,不得转载。

Python 基金会 —— 模块和包简介的更多相关文章

  1. Python之模块和包导入

    Python之模块和包导入 模块导入: 1.创建名称空间,用来存放模块XX.py中定义的名字 2.基于创建的名称空间来执行XX.py. 3.创建名字XX.py指向该名称空间,XX.名字的操作,都是以X ...

  2. 一文搞懂 Python 的模块和包,在实战中的最佳实践

    最近公司有个项目,我需要写个小爬虫,将爬取到的数据进行统计分析.首先确定用 Python 写,其次不想用 Scrapy,因为要爬取的数据量和频率都不高,没必要上爬虫框架.于是,就自己搭了一个项目,通过 ...

  3. Python之模块和包学习

    模块简介 python是由一系列的模块组成的,每个模块就是一个py为后缀的文件,同时模块也是一个命名空间,从而避免了变量名称冲突的问题.模块我们就可以理解为lib库,如果需要使用某个模块中的函数或对象 ...

  4. python 深入模块和包

    模块可以包含可执行语句以及函数的定义. 这些语句通常用于初始化模块. 它们只在 第一次 导入时执行.只在第一次导入的时候执行,第一次.妈蛋的第一次...后面再次导入就不执行了. [1](如果文件以脚本 ...

  5. (Python )模块、包

    本节开始学习模块的相关知识,主要包括模块的编译,模块的搜索路径.包等知识 1.模块 如果我们直接在解释器中编写python,当我们关掉解释器后,再进去.我们之前编写的代码都丢失了.因此,我们需要将我们 ...

  6. python基础-------模块与包(一)

    模块与包 Python中的py文件我们拿来调用的为之模块:主要有内置模块(Python解释器自带),第三方模块(别的开发者开发的),自定义模块. 目前我们学习的是内置模块与第三方模块. 通过impor ...

  7. python中模块,包,库的概念

    模块:就是.py文件,里面定义了一些函数和变量,需要的时候就可以导入这些模块. 包:在模块之上的概念,为了方便管理而将文件进行打包.包目录下第一个文件便是 __init__.py,然后是一些模块文件和 ...

  8. python的模块与包的导入

    类似于C语言的包含头文件去引用其他文件的函数,python也有类似的机制,常用的引入方法有以下 import 模块名 #模块名就是py文件名 #使用这种方法以后调用函数的时候要使用模块名.函数名()这 ...

  9. day21 python之模块和包

    一 模块 1 什么是模块? 常见的场景:一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀. 但其实import加载的模块分为四个通用类别: 1 使用python编 ...

随机推荐

  1. poj2763(树链剖分)

    题目链接:http://poj.org/problem?id=2763 题意:定一棵带边权的树,要求支持两种操作:1)询问树中某两点间的距离. 2)修改某条边的权值. 分析:树链剖分,边权修改,路径求 ...

  2. C++设计模式之建造者模式(三)

    4.引入钩子方法的建造者模式 建造者模式除了逐步构建一个复杂产品对象外.还能够通过Director类来更加精细地控制产品的创建过程.比如添加一类称之为钩子方法(HookMethod)的特殊方法来控制是 ...

  3. C#之网络

    首先很不好意思,前段时间把评论的功能给关掉啦,BUT NOW 此功能以开放,欢迎小伙伴们拍砖. 1网络 在网络环境下,我们最感兴趣的两个名称空间是System.Net和System.Net.Socke ...

  4. U10vim程序编辑器

    vim需要多加练习. 1.你可以将vim视为vi的高级版本.vi分成三种模式:一般模式,编辑模式和命令行模式. 一般模式:以vi打开一个文件就直接进入一般模式了(这也是默认的模式).在这个模式中,你可 ...

  5. SQLserver2012 tcp/ip 1433port问题解决方法

    非常多MSSQL安装完毕后,调用1433(默认port)是失败的,这边具体介绍下解决方法. 一..我们须要在电脑上开启telnet服务,定位问题须要.在cmd下使用telnet,假设报命令不存在说明没 ...

  6. dede 首页或列表页调用文章内容页body内容

    在使用dede过程,有的朋友会调调出文章的列表的内容出来,怎么调呢?当然是用dede的传参的数据查询语句了,方法如下: {dede:arclist flag=h typeid=2 row=1 titl ...

  7. STL源代码分析——STL算法remove删除算法

    前言 因为在前文的<STL算法剖析>中,源代码剖析许多.不方便学习,也不方便以后复习,这里把这些算法进行归类.对他们单独的源代码剖析进行解说.本文介绍的STL算法中的remove删除算法. ...

  8. 解决vmware卡的要死

    如题: 一般而言虚拟机不会卡的.CPU跟随你的操作而增减,内存设置vmware的推荐值就好.遇到卡的情况,检查一下如下情况. 两个方法: 1>内存分配最好是1G,512少了点 2>虚拟机的 ...

  9. D3js-堆栈图

    效果图: 源码: <%@ page language="java" import="java.util.*" pageEncoding="UTF ...

  10. Apache介绍

    怎样使用Apache许可证         若用户须要应用Apache许可证,请将下面演示样例使用适当的注视方法包括在作品源文件里,将括号"[]"中的字段以用户自身的区分信息来替换 ...