Python导入标准库和扩展库对象的几种方式

栏目: IT技术资讯 发布于: 2017-01-12 00:39:44

Python中的对象大概可以分为三类:内置对象、标准库对象和扩展库对象。其中内置对象是直接编译进解释器的可以直接使用,没有对应的Python源代码;标准库对象是随Python安装的,但是需要导入才能使用,相应的Python源代码在安装目录中的Lib目录中;扩展库需要单独安装之后再导入才能使用,其Python源代码在安装目录的Lib\site-packages目录中,也有一些扩展库的核心代码编译成为dll或pyd的动态链接库。关于扩展库的安装请参考Python扩展库安装工具pip的高级用法Python安装扩展库与打包成exe可执行文件的方法

本文重点介绍标准库对象和扩展库对象的导入和使用。

1)import 模块名 [as 别名]

使用这种方式导入以后,使用时需要在对象之前加上模块名作为前缀,必须以“模块名.对象名”的形式进行访问。如果模块名字很长的话,可以为导入的模块设置一个别名,然后使用“别名.对象名”的方式来使用其中的对象。
>>> import math     #导入标准库math
>>> math.sin(0.5)    #求0.5(单位是弧度)的正弦
0.479425538604203

2)from 模块名 import 对象名[ as 别名]
使用这种方式仅导入明确指定的对象,并且可以为导入的对象起一个别名。这种导入方式可以减少查询次数,提高访问速度,同时也可以减少程序员需要输入的代码量,不需要使用模块名作为前缀。

>>> from math import sin    #只导入模块中的指定对象
>>> sin(3)
0.1411200080598672
>>> from math import sin as f    #给导入的对象起个别名
>>> f(3)
0.1411200080598672

3)from 模块名 import *

这是上面用法的一种极端情况,可以一次导入模块中通过__all__变量指定的所有对象。
>>> from math import *  #导入标准库math中所有对象
>>> sin(3)   #求正弦值
0.1411200080598672
>>> gcd(36, 18)   #最大公约数
18

4)模块导入时的搜索路径

不管以哪种形式导入模块并使用其中的对象,Python首先在当前目录中查找需要导入的模块文件,如果没有找到则从sys模块的path变量所指定的目录中查找,如果仍没有找到模块文件则抛出异常提示模块不存在。可以查看sys模块中path变量的值来获知Python导入模块时搜索模块的路径,也可以使用append()方法向其中添加自定义的文件夹以扩展搜索路径。

Python还支持从zip文件中导入模块。假设当前文件夹中有个内含Vector3.py文件的testZip.zip文件,首先导入sys模块,然后执行sys.path.append(‘testZip.zip’),然后即可导入Vector3.py文件作为模块来使用。
>>> import sys
>>> sys.path.append('testZip.zip')
>>> import Vector3
>>> Vector3.__file__    #查看已导入模块对应的程序文件
'testZip.zip\\Vector3.py'

本文转载于微信公众号: Python小屋(Python_xiaowu),更多微信文章请扫描关注公众号:

Python小屋

本站文章除注明转载外,均为本站原创或编译。欢迎任何形式的转载,但请务必注明出处。
转载请注明:文章转载自 [http://www.php230.com]
本文标题:Python导入标准库和扩展库对象的几种方式
IT技术书籍推荐:
数据库技术丛书·MySQL技术内幕:InnoDB存储引擎(第2版)
数据库技术丛书·MySQL技术内幕:InnoDB存储引擎(第2版)
姜承尧 (David Jiang) (作者)
《MySQL技术内幕:InnoDB存储引擎(第2版)》由国内资深MySQL专家亲自执笔,国内外多位数据库专家联袂推荐。作为国内唯一一本关于InnoDB的专著,《MySQL技术内幕:InnoDB存储引擎(第2版)》的第1版广受好评,第2版不仅针对最新的MySQL 5.6对相关内容进行了全面的补充,还根据广大读者的反馈意见对第1版中存在的不足进行了完善,《MySQL技术内幕:InnoDB存储引擎(第2版)》大约重写了50%的内容。《MySQL技术内幕:InnoDB存储引擎(第2版)》从源代码的角度深度解析了InnoDB的体系结构、实现原理、工作机制,并给出了大量最佳实践,能帮助你系统而深入地掌握InnoDB,更重要的是,它能为你设计管理高性能、高可用的数据库系统提供绝佳的指导。 《MySQL技术内幕:InnoDB存储引擎(第2版)》一共10章,首先宏观地介绍了MySQL的体系结构和各种常见的存储引擎以及它们之间的比较;接着以InnoDB的内部实现为切入点,逐一详细讲解了InnoDB存储引擎内部的各个功能模块的实现原理,包括InnoDB存储引擎的体系结构、内存中的数据结构、基于InnoDB存储引擎的表和页的物理存储、索引与算法、文件、锁、事务、备份与恢复,以及InnoDB的性能调优等重要的知识;最后对InnoDB存储引擎源代码的编译和调试做了介绍,对大家阅读和理解InnoDB的源代码有重要的指导意义。 《MySQL技术内幕:InnoDB存储引擎(第2版)》适合所有希望构建和管理高性能、高可用性的MySQL数据库系统的开发者和DBA阅读。
最新互联网资讯
Linux I/O 重定向基础
发布于 2017-01-19 18:03:54
深入 Linux I/O 重定向
发布于 2017-01-19 18:22:59
fastjson 1.2.24 发布,Java的JSON处理器
发布于 2017-01-19 18:30:02
通过Nginx定义Header头信息
发布于 2017-01-19 17:36:26
微信头条