Python3.2官方文档教程--深入模块

2024-03-02 20:48

本文主要是介绍Python3.2官方文档教程--深入模块,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

4.1 深入模块

一个模块可以包含可执行语句和方法定义。这些语句用来初始化模块。当模块第一次被导入到其他地方时候这些语句将会执行。

每个模块都有自己私有的符号表, 定义在模块内的所有方法可以把它当做全局符号表来用。因此,模块的作者可以在模块中用全局变量而不同担心与用户全局变量的意外冲突。另一方面,如果你确切地知道自己在做什么,你可以使用引用模块函数的表示法访问模块的全局变量。Modname.itemnae. 
模块中可以导入其他模块。习惯上把所有的import语句放在一个模块的开始位置,但这不是强制的。导入的模块名称将会在放在正在导入模块的符号表中。例如:

还有一种import语句的变体,可以从一个模块中将名字直接导入到当前模块的符号表中。

>>> from fibo import fib, fib2

>>> fib(500)

1 1 2 3 5 8 13 21 34 55 89 144 233 377

这种方式不会把模块名字放在本地符号表中。(例如,fibo是没有定义的)

还有一种导入所有定义模块的名称的变体

>>> from fibo import*

>>> fib(500)

1 1 2 3 5 8 13 21 34 55 89 144 233 377

这种方式会导入除以下划线_开始之外的开头所有名称。在许多情况下,python开发者不会用这种工具。因为它会在解释器中引入一些未知的名称集合,有可能隐藏一些你已经定义的方法。

注意,一般而言,从模块或者包中import * 这种做法是不赞成的,因为它常常影响代码的可读性。但是,你可以用它来保存在交互session中的输入

注意: 为了效率,在每一个解释会话中每个模块只能允许导入一次。 因此,如果你修改你的模块,你必须重启python解释器。Or仅仅是一个你想交互测试的模块,你可以用方法

Imp.reload(),eg,import imp; imp.reload(moduleName);

4.1.1 像脚本一样执行python

当用如下方法运行一个python脚本,

Python fibo.py <arguments>

python中的代码将会被执行,就像你导入一样。但是方法”_name_”将会被设置为”_mian_”.

这就意外着可以再你的模块末尾将会添加如下方法:

if __name__ == "__main__":

import sys

fib(int(sys.argv[1]))

你可以在导入的模块中像脚本一样运行python代码,因为这些命令解析的代码仅当模块被当做主文件执行时会被运行。

$ python fibo.py 50

1 1 2 3 5 8 13 21 34

如果仅仅是导入,代码不会执行。

>>> import fibo

>>>

这种方法常用来提供一个便利的用户接口给一个模块,或者为了测试的需要。

4.1.2 模块的搜索路径

当一个名叫spam的模块导入时,解释器首先会用这个名称在内置模块中寻找。如果没有发现 ,它会给定的sys.path路径下的目录中查找spam.py的文件。Sys.path在如下位置被初始化:

l 包含输入脚本的目录或当前目录

l PYTHONPATH,(目录名称的列表,相当于shell变量的path) 

l 安装的默认路径

初始化后Python程序就会修改sys.path.包含正在运行脚本的目录常放在查找路径的开始。在标准库路径的前面。这就意外着在这个路径下的脚本不应该与库文件具有相同的名称。

否则当导入一个模块时候python将会把脚本当做模块加载,这通常会导致一个错误。 

4.1.3 编译python文件

作为一个为使用大量标准模块的小程序启动时间加速的重要方式,如果在spam.py所在的目录存在一个名为span.pyc的文件,这被认为是模块spamd的字节码预编译的版本。

创建spam.pyc时文件spam.py的修改时间版本会被记录在spam.pyc文件中。如果这两者不一致,那么.pyc文件就会忽略。

通常你无需要自行创建spam.pyc文件,每次spam.py成功编译后,都厚尝试将编译的版本写入spam.pyc文件中。如果尝试写入失败后,也不会引发什么错误。不论什么错误。 Spam.pyc文件的内容是平台无关的,所以一个python模块目录可以被不同体系架构的机器共享。

这篇关于Python3.2官方文档教程--深入模块的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

C#实现一键批量合并PDF文档

《C#实现一键批量合并PDF文档》这篇文章主要为大家详细介绍了如何使用C#实现一键批量合并PDF文档功能,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言效果展示功能实现1、添加文件2、文件分组(书签)3、定义页码范围4、自定义显示5、定义页面尺寸6、PDF批量合并7、其他方法

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方

基于C#实现PDF转图片的详细教程

《基于C#实现PDF转图片的详细教程》在数字化办公场景中,PDF文件的可视化处理需求日益增长,本文将围绕Spire.PDFfor.NET这一工具,详解如何通过C#将PDF转换为JPG、PNG等主流图片... 目录引言一、组件部署二、快速入门:PDF 转图片的核心 C# 代码三、分辨率设置 - 清晰度的决定因

Python自动化处理PDF文档的操作完整指南

《Python自动化处理PDF文档的操作完整指南》在办公自动化中,PDF文档处理是一项常见需求,本文将介绍如何使用Python实现PDF文档的自动化处理,感兴趣的小伙伴可以跟随小编一起学习一下... 目录使用pymupdf读写PDF文件基本概念安装pymupdf提取文本内容提取图像添加水印使用pdfplum

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

深入解析C++ 中std::map内存管理

《深入解析C++中std::map内存管理》文章详解C++std::map内存管理,指出clear()仅删除元素可能不释放底层内存,建议用swap()与空map交换以彻底释放,针对指针类型需手动de... 目录1️、基本清空std::map2️、使用 swap 彻底释放内存3️、map 中存储指针类型的对象