1.模块(module)

1.1 模块定义

通常模块为一个.py文件,其他可作为module的文件类型还有".pyo"、".pyc"、".pyd"、".so"、".dll"。

module 可看作一个工具类,可共用或者隐藏代码细节,将相关代码放置在一个module以便让代码更好用、易懂,让coder重点放在高层逻辑上。

module能定义函数、类、变量,也能包含可执行的代码。

1.2 模块作用

1.大大提高了代码的可维护性。

2.编写代码不必从零开始。当一个模块编写完毕,就可以被其他地方引用。我们在编写程序的时候,也经常引用其他模块,包括Python内置的模块和来自第三方的模块。

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

1.3  模块来源

①Python内置的模块(标准库)②第三方模块 ③自定义模块。

1.4 模块导入本质

把引用的python文件解释一遍。

1.5  模块导入方法

import module  #引用一个模块module
import module as md #引用模块module,使用别名md。代码中只能写成md,不能写module
import module1, module2 #同时引用多个模块module1和module2
from module import logger #仅引用module中的logger函数。代码中可直接写成logger,无需使用module.logger
from module import logger as frank #引用module中的logger函数,使用别名frank。代码中只能直接写成frank,不能写logger

1.6 模块导入案例解析

1.6.1 import引入

模块可以包含可执行的语句和函数的定义,这些语句的目的是初始化模块,它们只在模块名第一次遇到导入import语句时才执行,模块spam定义如下:

#spam.py
print('from the spam.py') money=1000 def read1():
print('spam->read1->money',money) def read2():
print('spam->read2 calling read')
read1() def change():
global money
money=0

模块定义好后,我们可以使用 import语句来引入模块,语法如下:

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

案例1:第一次引用spam模块时,可执行spam中语句。

import spam 
执行结果:
from the spam.py

案例2:模块间的同名函数或变量完全不冲突。

#测试money和spam.money不冲突(变量)
import spam
money=10
print(spam.money)
执行结果:
from the spam.py
1000
#测试read1与spam.read1不冲突(函数)
import spam
def read1():
print('========')
spam.read1()
执行结果:
from the spam.py
spam->read1->money 1000
#执行spam.change()操作的全局变量money仍然是spam中的
import spam
money=1
spam.change()
print(money)
执行结果:
from the spam.py
1

案例3:为已经导入的模块起别名的方式对编写可扩展的代码很有用

假设有两个模块xmlreader.py和csvreader.py,它们都定义了函数read_data(filename):用来从文件中读取一些数据,但采用不同的输入格式。可以编写代码来选择性地挑选读取模块,例如:

if file_format == 'xml':
import xmlreader as reader #reader为模块别名
elif file_format == 'csv':
import csvreader as reader #reader为模块别名
data=reader.read_date(filename)

案例4:在一行导入多个模块

import sys,os,re

 1.6.2 from..import..导入

1.7 模块搜索路径

2. 包(package)

通常包总是一个目录,包目录下为首的一个文件便是 __init__.py,然后是一些模块文件和子目录。假如子目录中也有 __init__.py 那么它就是这个包的子包。

可以使用import导入包,或者from + import来导入包中的部分模块。

3.import的特点

import语句是可以在程序中的任意位置使用。一个程序中多次引用同一个模块时,模块不会被重复导入。

为了防止你重复导入,python的优化手段是:第一次导入后就将模块名加载到内存了,后续的import语句仅是对已经加载大内存中的模块对象增加了一次引用,不会重新执行模块内的import语句。

# 文件test1.py
import test2
print test2.attr
# 文件test2.py
import test1
attr = 'hello world'
# 文件test.py
import test1

执行test.py,输出结果为:hello world

说明:test.py中已经引用了test1,当文件test2.py再次引用test1时,则忽略引用。

参考文档:

Python3之模块及包的导入

Python 3.x可能是史上最详解的【导入(import)】

import的本质解析

python import详解

【Python实战】模块和包导入详解(import)的更多相关文章

  1. Python之模块和包导入

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

  2. python模块与包的详解

    一模块 1.什么是模块? 常见场景:一个模块包含python定义和声明的文件,文件名就是模块名字加上.py的后缀 2.为何要是用模块 如果你退出python解释器然后重新进入,那么你之前定义的函数或者 ...

  3. python常用模块numpy解析(详解)

    numpy模块 关注公众号"轻松学编程"了解更多. 以下命令都是在浏览器中输入. cmd命令窗口输入:jupyter notebook 后打开浏览器输入网址http://local ...

  4. python random模块(随机数)详解

    使用前要先导入random模块 import random random.randomrandom.random()用于生成一个0到1的随机符点数: 0 <= n < 1.0 random ...

  5. Python之路-pandas包的详解与使用

    什么是pandas pandas是一种Python数据分析的利器,是一个开源的数据分析包,最初是应用于金融数据分析工具而开发出来的,因此pandas为时间序列分析提供了很好的支持.pandas是PyD ...

  6. python linecache模块读取文件用法详解

    linecache模块允许从任何文件里得到任何的行,并且使用缓存进行优化,常见的情况是从单个文件读取多行. linecache.getlines(filename) 从名为filename的文件中得到 ...

  7. Python urllib模块urlopen()与urlretrieve()详解

    1.urlopen()方法urllib.urlopen(url[, data[, proxies]]) :创建一个表示远程url的类文件对象,然后像本地文件一样操作这个类文件对象来获取远程数据.参数u ...

  8. python常用模块:包的使用、init作用、相对导入绝对导入与内置函数

    今天主要讲的内容有: 一.包的详解二.相对导入和绝对导入三.内置模块补充 一.包的详解 1.包是什么 包其实也是一个模块,只不过是一个大的模块下包含一堆模块的载体 本质上也是一个文件夹,与普通文件的区 ...

  9. kafka实战教程(python操作kafka),kafka配置文件详解

    kafka实战教程(python操作kafka),kafka配置文件详解 应用往Kafka写数据的原因有很多:用户行为分析.日志存储.异步通信等.多样化的使用场景带来了多样化的需求:消息是否能丢失?是 ...

随机推荐

  1. 开源的类似于Apache ab的压力测试命令行工具SuperBenchmarker

    SuperBenchmarker 是ㄧ个开源的类似于Apache ab的压力测试命令行工具.可以在 .NET 4.52+ 或者 .NET Core 2.0+ 平台上运行. 可支持Get.Post.Pu ...

  2. 12.22 大湾区.NET Meet 大会

    今年的 Connect(); 主题更加聚焦开发者工具生产力.开源,以及无服务器(Serverless)云服务. Visual Studio 2019 AI 智能加持的 IntelliCode.实时代码 ...

  3. 腾迅云CDN的使用

    一开始,我是想和七牛云一样,将腾迅云的对象存储作为网盘使用,不过在折腾的时间,搞不清楚腾迅云CDN的用法,最后看文档,看博客,大概了解了 这里讲两种用法,一种是结合对象存储,作一个静态网站或下载站,但 ...

  4. jquery删除内容是动态修改序号

    如图,点击删除图标的时候要删除当前的一条记录,同时界面上的序号要动态的排列好 以下是html结构: jquery实现思路: 首先,需要获取到当前要删除盒子的序号$indexCur,然后遍历父盒子,取出 ...

  5. mysql的学习笔记(二)

    1.数据类型,存储的类型. 整型 TINYINT 有符号-128到127 无符号值:0到255 1字节 SMALLINT 有符号 -32768到32767 0到65535 2字节 MEDIUMINT ...

  6. Vue基于vue-quill-editor富文本编辑器使用心得

    vue-quill-editor的guthub地址,现在市面上有很多的富文本编辑器,我个人还是非常推荐Vue自己家的vue-quill-deitor,虽然说只支持IE10+,但这种问题,帅给别人吧! ...

  7. mysql索引规范

    索引并不是越多越好!索引可以提高查询效率,但会降低增删改效率.但多了甚至会降低查询效率. Innodb是按照主键索引的顺序来组织表,如没有建立主键,mysql会选择第一个非空唯一索引做为主键,或生成一 ...

  8. python异常处理的哲学

    所谓异常指的是程序的执行出现了非预期行为,就好比现实中的做一件事过程中总会出现一些意外的事.异常的处理是跨越编程语言的,和具体的编程细节相比,程序执行异常的处理更像是哲学.限于认知能力和经验所限,不可 ...

  9. Asp.Net Core在CentOS部署与注意

    部署具体步骤参考:将ASP.NET Core应用程序部署至生产环境中(CentOS7) 1.wwwroot是放静态文件的,Startup的配置里面要app.UseStaticFiles(); 2.在不 ...

  10. 第一册:lesson 113.

    原文:Small changes. question:Who has got some small changes? Fares,please! Trafalgar Square,please. I' ...