Python中模块

2024-03-29 16:04
文章标签 python 模块

本文主要是介绍Python中模块,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

基本概念

**模块 module:**一般情况下,是一个以.py为后缀的文件

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

包 package

当一个文件夹下有   init   .py时,意为该文件夹是一个包(package),其下的多个模块(module)构成一个整体,而这些模块(module)都可通过同一个包(package)导入其他代码中。

  • 其中   init   .py文件 用于组织包(package),方便管理各个模块之间的引用、控制着包的导入行为
  • from pacakge_1 import *这种形式的写法,需在  init  .py中加上:   all    = [‘file_a’, ‘file_b’]。   all   是一个重要的变量,用来指定此包(package)被import *时,哪些模块(module)会被import进【当前作用域中】
  •    path   也是一个常用变量,是个列表,默认情况下只有一个元素,即当前包(package)的路径

sys.modules、命名空间、模块内置属性

sys.modules 是一个 将模块名称(module_name)映射到已加载的模块(modules) 的字典。可用来强制重新加载modules。Python一启动,它将被加载在内存中。当我们导入新modules,sys.modules将自动记录下该module;当第二次再导入该module时,Python将直接到字典中查找,加快运行速度

命名空间

  • 每个函数function 有自己的命名空间,称local namespace,记录函数的变量。
  • 每个模块module 有自己的命名空间,称global namespace,记录模块的变量,包括functions、classes、导入的modules、module级别的变量和常量
  • build-in命名空间,它包含build-in function和exceptions,可被任意模块访问。

查找顺序:local namespace ->global namespace ->build-in namespace 

对于闭包,若在local namespace找不到该变量,则继续查找父函数的local namespace。

内置函数locals()、globals()返回一个字典。区别:前者只读、后者可写

from module_A import X  VS  import module_A(语言理解)

内置属性

  •    name   直接运行本模块,   name   值为   main   ;import module,   name   值为模块名字
  •    file   当前 module的绝对路径
  •    dict   
  •    doc   
  •    package   
  •    path   :当前包(package)的路径

导入模块

绝对导入

 绝对导入:所有的模块import都从“根节点”开始。根节点的位置由sys.path中的路径决定,项目的根目录一般自动在sys.path中。如果希望程序能处处执行,需手动修改sys.path

import sys,os
BASE_DIR = os.path.dirname(os.path.abspath(__file__))#存放c.py所在的绝对路径sys.path.append(BASE_DIR)from B.B1 import b1#导入B包中子包B1中的模块b1

相对导入

只关心相对自己当前目录的模块位置就好。不能在包(package)的内部直接执行(会报错)。

常见错误❌ValueError: Attempted relative import beyond toplevel package

单独导入包(package)

c.py:

import B

B.B1.b2.print_b2() 

Error 报错 ❌

①一个.py文件调用另一个.py文件中的类。
如 a.py(class A)、b.py(class B),a.py调用b.py中类B用:from b import B
②一个.py文件中的类 继承另一个.py文件中的类。如 a.py(class A)、b.py(class B),a.py中类A继承b.py类B。

导入包

 和模块导入基本一致,只是导入包时,会执行这个   init   .py,而不是模块中的语句。

  • 如果**只是单纯地导入包【形如:import xxx】**,而包的   init   .py中有没有明确地的其他初始化操作,则:此包下的模块 是不会被自动导入的。当然该包是会成功导入的,并将包名称放入当前.py的Local命名空间中。

import与_import_

在Python中,__import__ 是一个内置函数,用于动态地导入模块。它的使用方式如下:

__import__(name, globals=None, locals=None, fromlist=(), level=0)

  • name 是要导入的模块名称。
  • globals 是一个字典,用于指定导入过程中的全局命名空间。如果不提供,则使用当前全局命名空间。
  • locals 是一个字典,用于指定导入过程中的局部命名空间。如果不提供,则使用 globals
  • fromlist 是一个可选参数,如果指定了,它是一个包含要导入的子模块或对象名称的列表。
  • level 是相对导入的级别。如果指定了 level,则 name 必须是相对于当前模块的路径。如果未指定,则默认为0,表示标准的绝对导入。

通常情况下,推荐使用 import 语句来导入模块,而不是直接使用 __import__ 函数,因为 import 语句更加直观和易于理解。但是,在某些特殊情况下,__import__ 可能会更灵活,例如需要在运行时动态地确定要导入的模块名称时。

directory = os.path.dirname(model_url)sys.path.append(directory)basename =  model_url.split('\\')[-1]  # 将路径按照反斜杠分割,并取最后一个部分filename = basename.split('.')[0]  # 将文件名按照点分割,并取第一个部分module=__import__(filename)

理解Python在执行import语句

  1. 创建一个新的、空的module对象(它可能包含多个module);
  2. 将该module对象 插入sys.modules中;
  3. 装载module的代码(如果需要,需先编译);
  4. 执行新的module中对应的代码。

在执行step3时,首先需找到module程序所在的位置,如导入的module名字为mod_1,则解释器得找到mod_1.py文件,搜索顺序是:
当前路径(或当前目录指定sys.path)--->PYTHONPATH---->Python安装设置相关的默认路径。

对于不在sys.path中,一定要避免用import导入 自定义包(package)的子模块(module),而要用from…import… 的绝对导入 或相对导入,且包(package)的相对导入只能用from形式

顺序导入

(Local命名空间独立,无传递!

from moduleB import ClassB有两个过程,先from module,后import ClassB

循环导入

 

解决方案

方法1----->延迟导入(lazy import):把import语句写在方法/函数里,将它的作用域限制在局部。(此法可能导致性能问题)
方法2----->将from x import y改成import x.y形式
方法3----->组织代码(重构代码):更改代码布局,可合并或分离竞争资源。
合并----->都写到一个.py文件里;
分离–>把需要import的资源提取到一个第三方.py文件中。
总之,将循环变成单向。

多数知识图源自:模块管理-预备知识-CSDNPython入门技能树

这篇关于Python中模块的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/859028

相关文章

Python中zfill()方法的详细说明

在Python编程中,处理字符串和数字格式是常见的任务。zfill()方法是一个字符串方法,用于将一个数字填充(pad)为固定长度的字符串。这个方法特别适用于确保数字显示的一致性和格式化输出。 方法定义 zfill()方法是str类的实例方法,其定义如下: str.zfill(width) width: 一个整数,表示填充后字符串的总宽度。 如果原字符串的长度已经等于或超过width,

miniTry:Python实现web搜索(全自动+程序操控)

声明:本问给出了全部代码--可以复现--亲测有效  :)  [ 代码为图片--> 强制自己去敲一次  又不多] 1.打开网站: 2.利用id去定位到我们要进行输入的内容(bing可以直接进行搜索,而csdn需要登录,所以我们用csdn做演示) 先找到input的id  (查看html代码即可得到--我们此处的id :  sb_form_q ) 3.然后我们就成功定位到i

第三篇:Python编程基础:掌握核心语法与开发技巧

Python编程基础:掌握核心语法与开发技巧 1 引言 在这个信息化迅速蔓延的世界中,Python语言如同钥匙一般开启了通往各种可能性的大门。无论你是数据科学家、网络工程师、机器学习专家,还是仅仅对自动化办公感兴趣的办公室人员,Python因其易于学习且功能强大的特性,成为了跨领域的首选编程语言。深入理解Python的基础语法对于任何希望通过编程解决问题的人来说都是至关重要的。本篇文章旨在

Python中使用pip下载安装tensorflow

安装了python后,使用pip命令下载安装第三方库的地址默认是python官网,下载速度慢,且容易超时。 为提高下载速度,可以使用国内的一些镜像网站,例如安装tensorflow 最原始从官网下载:   pip install tensorflow 从国内镜像网站安装最新版本:  pip install tensorflow -i  http://pypi.douban.com/simpl

Python中matplotlib绘制密度散点图的方法

本文介绍基于Python语言的matplotlib模块,对Excel表格文件中的指定数据,加以密度散点图绘制的方法。   首先,明确一下本文的需求。   现有一个.csv格式的表格文件,其各列数据的开头部分如下图所示。其中,对于名称为26的这1列(左侧紫色框内数据),我们希望提取其数值等于1的所有行,并对这些行中的NIR_predict列与NIR_true列(右侧紫色框内数据)的数值加以密

python网络爬虫爬取需要的数据

要爬取网站的数据,你可以使用 Python 的 requests 库来发送 HTTP 请求,并使用 BeautifulSoup 库来解析返回的 HTML 内容。但是,在此之前,你需要检查该网站的 robots.txt 文件,以确认是否允许爬虫抓取特定页面的数据。 robots.txt 文件通常位于网站的根目录下,可以通过将 robots.txt 添加到网站域名后访问。例如,对于 https://

python学习笔记----python基础语法(二)

一、字面量 在 Python 中,字面量 是一种直接在代码中表示其自身值的数据。字面量用于创建值,并且可以直接被 Python 的解释器识别和处理。不同类型的数据有不同的字面量形式。下面是一些常见的字面量类型: 二、注释 注释:在程序代码中对程序进行解释说明的文字。作用:注释不是程序,不能被执行,只是对程序代码进行解释说明,让别人可以看懂程序代码的作用,能够大大增强程序的可读

【Python】使用 argparse 来加载yml文件的内容 - 2

继续上一节:【Python】YAML(.yml)文件简介以及python示例 - 1 使用 argparse 模块来读取 .yml 文件并不是直接由 argparse 完成的,但可以使用 argparse 来处理命令行参数,使得用户能够指定 .yml 配置文件的路径,然后结合 PyYAML 来加载这个文件的内容。这种方式常见于需要配置文件来启动Python脚本的情况,例如各类应用和服务的启动脚本

【python】语言学习笔记--用来记录总结

请问以下变量哪些是tuple类型: a = ()b = (1)c = [2]d = (3,)e = (4,5,6) answer在Python中,元组(tuple)是由逗号分隔的一组值组成的有序序列,通常用圆括号括起来。让我们逐个检查变量,看哪些是元组类型:a = ():这是一个空元组,是元组类型。b = (1):这是一个包含一个整数值的表达式,而不是元组类型。c = [2]:这是一

Python项目开发实战:怎么删除恶意代码

注意:本文的下载教程,与以下文章的思路有相同点,也有不同点,最终目标只是让读者从多维度去熟练掌握本知识点。 下载教程:Python项目开发实战_恶意代码删除_编程案例解析实例详解课程教程.pdf 1、特点 在Python项目开发中,恶意代码的存在是一个严重的安全威胁。恶意代码,又称恶意软件,是指那些在没有用户明确授权的情况下,执行非法或有害操作的代码。它们通常具有隐蔽性、破坏性和传播性等