python基础---模块与包

1、模块导入方法

常见的场景:

一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀,导入模块可以实现功能的重复利用

import加载的模块分为四个通用类别: 

1 使用python编写的代码(.py文件)

2 已被编译为共享库或DLL的C或C++扩展

3 包好一组模块的包

4 使用C编写并链接到python解释器的内置模块

a. import语句

python 内置了很多模块,比如os、sys、time等,也可以是自定义模块、模块包、C扩展等,使用import无法区分导入的模块类型

import 模块名

例如:导入spam.py

import spam(不含.py)

导入多个模块:

import os,time,sys

模块可以包含可执行的语句和函数的定义,这些语句的目的是初始化模块,它们只在模块名第一次遇到导入import语句时才执行(import语句是可以在程序中的任意位置使用的,且针对同一个模块import很多次,为了防止你重复导入,python的优化手段是:第一次导入后就将模块名加载到内存了,后续的import语句仅是对已经加载大内存中的模块对象增加了一次引用,不会重新执行模块内的语句)

每个模块都是一个独立的名称空间,定义在这个模块中的函数,把这个模块的名称空间当做全局名称空间,这样我们在编写自己的模块时,就不用担心我们定义在自己模块中全局变量会在被导入时,与使用者的全局变量冲突

导入模块干了哪些事:
1 执行源文件
2 以一个源文件的全局名称空间
3 在当前位置拿到一个模块名,指向2创建的名称空间

#测试一:money与spam.money不冲突
#test.py
import spam
money=10
print(spam.money)

输出:
from the spam.py
1000
 
#测试二:read1与spam.read1不冲突
#test.py
import spam
def read1():
     print(‘========‘)
spam.read1()

输出:
from the spam.py
spam->read1->money1000

#测试三:执行spam.change()操作的全局变量money仍然是spam中的
#test.py
import spam
money=1
spam.change()
print(money)

输出:
from the spam.py
1

模块别名功能

练习:

有两钟sql模块mysql和oracle,根据用户的输入,选择不同的sql功能

#mysql.py
def sqlparse():
    print(‘from mysql sqlparse‘)
 
#oracle.py
def sqlparse():
    print(‘from oracle sqlparse‘)
 
#test.py
db_type=input(‘>>: ‘)
if db_type == ‘mysql‘:
    import mysql as db
elif db_type == ‘oracle‘:
    import oracle as db
 
db.sqlparse()

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

if file_format == ‘xml‘:
    import xmlreader asreader
elif file_format == ‘csv‘:
    import csvreader asreader
data=reader.read_date(filename)

b. from…import语句

from 模块名  import 模块名中的方法

例如:from spamimport money,read1,read2,change

如果模块中的方法太多,可以使用:

from spam import  *     (不推荐使用,容易与执行文件的命名空间冲突)

__all__=[‘money‘,‘x‘]      #对from spam import * 有用,之后导入money、x方法
_money=1000             #对from spam import * 有用,不会导入这个方法

对比import spam,会将源文件的名称空间‘spam‘带到当前名称空间中,使用时必须是spam.名字的方式,而from 语句相当于import,也会创建新的名称空间,但是将spam中的名字直接导入到当前的名称空间中,在当前名称空间中,直接使用名字就可以了

#spam.py
print(‘from the spam.py‘)

money=0
def read1():
    print(‘spam->read1->money‘,money)

def read2():
    print(‘spam->read2 calling read‘)
    read1()

def change():
    global money
    money=0 
 
# 执行文件
from spam import money,read1,read2,change
money=0
print(money)
print(read1)

输出:
from the spam.py                    #首先执行spam.py
0                      #仍然是当前执行文件的命名空间中的money
<function read1 at 0x00000000026DE950>

优点:使用源文件内的名字时无需加前缀,使用方便

缺点:容易与当前文件的名称空间内的名字混淆

c. 模块搜索路径

模块只在第一次导入时才会执行,之后的导入都是直接引用内存已经存在的结果
import sys
print(‘spam‘ in sys.modules)            #存放的是已经加载到内的模块

注意:自定义的模块名一定不要与python自带的模块名重名

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

import time
import importlib

import spam           #导入模块会把硬盘中的模块内容加载到内存中
time.sleep(20)
import spam           #再次导入会直接从内存中查找,忽略硬盘中模块内容
print(spam.money)
importlib.reload(spam)         #会重新加载模块(只在测试环境使用)
print(spam.money)

import sys

print(sys.path)              #模块的搜索路径

sys.path从以下位置初始化

1  执行文件所在的当前目录

2  PTYHONPATH(包含一系列目录名,与shell变量PATH语法一样)

3  依赖安装时默认指定的

加入模块路径:

import sys
print(sys.path)
sys.path.insert(0,r‘要添加的模块路径‘)       #插入模块路径
sys.path.append(r‘要添加的模块路径‘)         #追加模块路径

d. 区分python文件的两种用途

文件当做脚本(执行文件)运行时__name__等于__main__
文件当做模块被加载运行时__name__等于模块名

# m1.py
import os,sys
x=1
def func1():
    print(‘from m1‘)
def func2():
    print(‘from m2‘)
def func3():
    print(‘from m3‘)
# print(__name__)
#文件当做脚本运行时__name__等于__main__
#文件当做模块被加载运行时__name__等于模块名
if __name__ == ‘__main__‘:
    #当做脚本使用时才执行
    func1()
    func2()
    func3() 
# run.py
 
import m1            #导入m1模块
m1.func3()

e. 包

python3中创建文件夹会自动创建__init__.py

python2中创建包需要手动创建__init__.py

1. 无论是import形式还是from...import形式,凡是在导入语句中(而不是在使用时)遇到带点的,都要第一时间提高警觉:这是关于包才有的导入语法

2. 包是目录级的(文件夹级),文件夹是用来组成py文件(包的本质就是一个包含__init__.py文件的目录)

3. import导入文件时,产生名称空间中的名字来源于文件,import 包,产生的名称空间的名字同样来源于文件,即包下的__init__.py,导入包本质就是在导入该文件

强调:

1. 在python3中,即使包下没有__init__.py文件,import 包仍然不会报错,而在python2中,包下一定要有该文件,否则import 包报错

2. 创建包的目的不是为了运行,而是被导入使用,记住,包只是模块的一种形式而已,包即模块

3.凡是在导入时带点的,点的左边都必须是一个包

时间: 2024-08-06 11:57:22

python基础---模块与包的相关文章

python基础----模块、包

一 模块                                                                                                   ㈠ 什么是模块? 一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀. ㈡ 为何要使用模块? 如果你退出python解释器然后重新进入,那么你之前定义的函数或者变量都将丢失,因此我们通常将程序写到文件中以便永久保存下来,需要时就通过python test.p

python基础-------模块与包(四)

configparser模块与 subprcess 利用configparser模块配置一个类似于 windows.ini格式的文件可以包含一个或多个节(section),每个节可以有多个参数(键=值). 配置成这样一个文件 [DEFAULT]ServerAliveInterval = 45Compression = yesCompressionLevel = 9ForwardX11 = yes [bitbucket.org]User = hg [topsecret.server.com]Por

python基础-------模块与包(三)

re模块正则表达式 正则表达式常用符号: [ re模块使用方法]: match(string[, pos[, endpos]]) | re.match(pattern, string[, flags]): 这个方法将从string的pos下标处起尝试匹配pattern:如果pattern结束时仍可匹配,则返回一个Match对象:如果匹配过程中pattern无法匹配,或者匹配未结束就已到达endpos,则返回None. pos和endpos的默认值分别为0和len(string):re.match

python 深入模块和包

模块可以包含可执行语句以及函数的定义. 这些语句通常用于初始化模块. 它们只在 第一次 导入时执行.只在第一次导入的时候执行,第一次.妈蛋的第一次...后面再次导入就不执行了. [1](如果文件以脚本的方式执行,它们也会运行.) 每个模块都有自己的私有符号表, 模块内定义的所有函数用其作为全局符号表. 被导入的模块的名字放在导入模块的全局符号表中. import 语句的一个变体直接从被导入的模块中导入名字到导入模块的符号表中. 例如: >>> >>> from fibo

Python的模块与包如何使用?

本文和大家分享的主要是python模块与包相关内容,一起来看看吧,希望对大家学习python有所帮助. 一.Python 模块简介 在开发过程中,随着程序代码越写越多,在一个文件里代码就会越来越长,越来越不容易维护. 为了编写可维护的代码,我们把很多函数分组,分别放到不同的文件里,这样,每个文件包含的代码就相对较少,很多编程语言都采用这种组织代码的方式.在 Python 中,一个 .py 文件就称之为一个模块(Module). 之前我们学习过函数,知道函数是实现一项或多项功能的一段程序 .其实模

python之模块与包

一模块 二包 一模块 常见的场景:一个模块就是一个包含了python定义和声明的文件,文件名就是模块名字加上.py的后缀. 但其实import加载的模块分为四个通用类别: 1 使用python编写的代码(.py文件) 2 已被编译为共享库或DLL的C或C++扩展 3 包好一组模块的包 4 使用C编写并链接到python解释器的内置模块 为什么要使用模块 如果你退出python解释器然后重新进入,那么你之前定义的函数或者变量都将丢失,因此我们通常将程序写到文件中以便永久保存下来,需要时就通过pyt

selenium + python自动化测试unittest框架学习(四)python导入模块及包知识点

在写脚本的时候,发现导入某些模块,经常报错提示导入模块失败,这里来恶补下python导入模块的知识点. 1.模块导入时文件查找顺序 在脚本中,import xxx模块时的具体步骤: (1)新建一个module (2)将module插入到sys.module (3)查找module的路径,查找的顺序为先查找当前使用导入模块的文件同一级目录,之后是python的搜索模块的路径集sys.path,最后是python所添加的默认环境变量的路径Python path (4)module查找到之后装载mod

Python之模块和包学习

模块简介 python是由一系列的模块组成的,每个模块就是一个py为后缀的文件,同时模块也是一个命名空间,从而避免了变量名称冲突的问题.模块我们就可以理解为lib库,如果需要使用某个模块中的函数或对象,则要导入这个模块才可以使用,除了系统默认的模块(内置函数)不需要导入外. 导入直接使用如下语法:  import 模块名称 (不要.py后缀) 这样导入成功后,就可以在另外一个模块中使用被导入模块的功能函数或对象. 举例如下,比如在F:\Pro-files\workspace\myPython目录

Python学习---模块和包

模块: 一个模块就是一个包含Python代码的文件,一个文件就是一个模块 为什么使用模块 1.现在程序开发文件比较大,都放在一个文件中维护不方便,拆分成多个文件方便维护和管理 2.模块可以增加代码的重用率 3.模块可以当做命名空间 如何定义自己的模块 模块本身就是一个文件,所有py代码都可以在文件中直接书写,不过我们开发公用模块时,最好在模块中书写一下内容 变量 模块中的属性 函数 单独的功能 类 相似功能组合 模块测试代码 临时使用,被导入时不会执行 测试代码: 测试代码经常在开发模块时用于测