Python模块、包(Package)概念与用法分析
本文实例讲述了Python模块、包(Package)概念与用法。分享给大家供大家参考,具体如下:
Python中”模块”的概念
在开发中,我们会有很多函数,我们可以把这些函数都放到一个文件。
比如function.py中:
#定义函数 def show(): print("jack") #定义变量 name = "tom"
在其他地方要使用其中的函数怎么办呢?
第一步:需要先引入
import funtions
第二步:通过文件名.函数名/变量名的方式使用
funtions.show() # jack print(funtions.name) # tom
另外一种导入方式
#另外一种导入方式 from funtions import * show() # jack print(name) #tom
要比较2种引入方式背后有什么不同,可以使用下面的方法
#打印局部变量符号表 print(locals()) #打印全局变量符号表 print(globals())
Python中包(Package)的概念
Package可以用来管理模块(同名的模块放入不同的包就不冲突了),要理解这个概念可以结合命名空间作用来理解。
创建Package:
在IDE中,右键->new->Python Package
创建之后会同时创建一个名叫__init__.py的文件,文件内容是空的。
这个__init__.py文件的作用可以认为是用来识别这个是一个包,而不是普通目录。
把我们的模块(公共函数funcitons.py)文件 放入这个包中,那么在引入这个模块的文件时候就不一样了:
#引入地址 包名.文件名 import common.funtions
这种引入方式我们要使用里面的函数:
common.funtions.show()
诶,这种方式怎么这么繁琐?
别急,我们还有一种引入方式呢。
from common.funtions import * show() # 直接使用函数
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python函数使用技巧总结》、《Python面向对象程序设计入门与进阶教程》、《Python数据结构与算法教程》、《Python字符串操作技巧汇总》、《Python编码操作技巧总结》及《Python入门与进阶经典教程》
希望本文所述对大家Python程序设计有所帮助。
相关推荐
-
Python开发常用的一些开源Package分享
一般安装完Python后,我会先装一些常用的Package.做个笔记,记录下来,以备查询: Web FrameWorks Tornado,访问:http://www.tornadoweb.org/en/stable/ Flask,访问:http://flask.pocoo.org/ Web.py,访问:http://webpy.org/ Tools xlrd,Excel处理利器,访问:http://www.python-excel.org/ lxml,XML处理,访问:http://lxml.d
-
python一键升级所有pip package的方法
pip_ungrade_all.py代码如下: # -*- coding: utf-8 -*- import pip from subprocess import call for dist in pip.get_installed_distributions(): call("pip install --upgrade " + dist.project_name, shell=True) 以管理身份执行脚本pip_ungrade_all.py # python pip_ungrade
-
对Python进行数据分析_关于Package的安装问题
一.为什么要使用Python进行数据分析? python拥有一个巨大的活跃的科学计算社区,拥有不断改良的库,能够轻松的集成C,C++,Fortran代码(Cython项目),可以同时用于研究和原型的构建以及生产系统的构建. 二.Python的优势与劣势: 1.Python是一种解释型语言,运行速度比编译型数据慢. 2.由于python有一个全局解释器锁(GIL),防止解释器同时执行多条python字节码,所以python不适用于高并发.多线程的应用程序. 三.使用Python进行数据分析常用的扩
-
使用Python的package机制如何简化utils包设计详解
package 机制 package是模块的集合,每一个Package的根目录下面都应当有一个__init__.py 文件.当解释器发现目录下有这个文件时,他就会认为这是一个Package,而不是一个普通的目录. 对于 package 机制的说明,其实官方文档已经有非常详尽的论述了,本文并不着眼于此. 简单来说,一个目录下如果包含 __init__.py ,则被 Python 视作一个 Python package.其中: __init__.py 中的东西,在初始化这个包时,会首先被加载 pac
-
python的正则表达式re模块的常用方法
1.re的简介 使用python的re模块,尽管不能满足所有复杂的匹配情况,但足够在绝大多数情况下能够有效地实现对复杂字符串的分析并提取出相关信息.python 会将正则表达式转化为字节码,利用 C 语言的匹配引擎进行深度优先的匹配. 复制代码 代码如下: import re print re.__doc__ 可以查询re模块的功能信息,下面会结合几个例子说明. 2.re的正则表达式语法 正则表达式语法表如下: 语法 意义 说明 "." 任意字符 "^" 字符串开始
-
python中requests模块的使用方法
本文实例讲述了python中requests模块的使用方法.分享给大家供大家参考.具体分析如下: 在HTTP相关处理中使用python是不必要的麻烦,这包括urllib2模块以巨大的复杂性代价获取综合性的功能.相比于urllib2,Kenneth Reitz的Requests模块更能简约的支持完整的简单用例. 简单的例子: 想象下我们试图使用get方法从http://example.test/获取资源并且查看返回代码,content-type头信息,还有response的主体内容.这件事无论使用
-
python标准日志模块logging的使用方法
最近写一个爬虫系统,需要用到python的日志记录模块,于是便学习了一下.python的标准库里的日志系统从Python2.3开始支持.只要import logging这个模块即可使用.如果你想开发一个日志系统, 既要把日志输出到控制台, 还要写入日志文件,只要这样使用: 复制代码 代码如下: import logging# 创建一个loggerlogger = logging.getLogger('mylogger')logger.setLevel(logging.DEBUG)# 创建一个ha
-
Python中os和shutil模块实用方法集锦
复制代码 代码如下: # os 模块 os.sep 可以取代操作系统特定的路径分隔符.windows下为 '\\'os.name 字符串指示你正在使用的平台.比如对于Windows,它是'nt',而对于Linux/Unix用户,它是 'posix'os.getcwd() 函数得到当前工作目录,即当前Python脚本工作的目录路径os.getenv() 获取一个环境变量,如果没有返回noneos.putenv(key, value) 设置一个环境变量值os.listdir(path) 返回指定目录
-
Python标准库之Sys模块使用详解
sys 模块提供了许多函数和变量来处理 Python 运行时环境的不同部分. 处理命令行参数 在解释器启动后, argv 列表包含了传递给脚本的所有参数, 列表的第一个元素为脚本自身的名称. 使用sys模块获得脚本的参数 复制代码 代码如下: print "script name is", sys.argv[0] # 使用sys.argv[0]采集脚本名称 if len(sys.argv) > 1: print "there are",
-
Python os模块介绍
os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径 os.chdir("dirname") 改变当前脚本工作目录:相当于shell下cd os.curdir 返回当前目录: ('.') os.pardir 获取当前目录的父目录字符串名:('..') os.makedirs('dirname1/dirname2') 可生成多层递归目录 os.removedirs('dirname1') 若目录为空,则删除,并递归到上一级目录,如若也为空,则删除,依此类推 os
-
Python的subprocess模块总结
subprocess意在替代其他几个老的模块或者函数,比如:os.system os.spawn* os.popen* popen2.* commands.* subprocess最简单的用法就是调用shell命令了,另外也可以调用程序,并且可以通过stdout,stdin和stderr进行交互. subprocess的主类 复制代码 代码如下: subprocess.Popen( args, bufsize=0, executable=None,
-
Python中内置的日志模块logging用法详解
logging模块简介 Python的logging模块提供了通用的日志系统,可以方便第三方模块或者是应用使用.这个模块提供不同的日志级别,并可以采用不同的方式记录日志,比如文件,HTTP GET/POST,SMTP,Socket等,甚至可以自己实现具体的日志记录方式. logging模块与log4j的机制是一样的,只是具体的实现细节不同.模块提供logger,handler,filter,formatter. logger:提供日志接口,供应用代码使用.logger最长用的操作有两类:配置和发
随机推荐
- MySQL无法创建外键的原因及解决方法
- Python创建二维数组实例(关于list的一个小坑)
- linux下使用perl获取本机ip的几种方法介绍
- Python中DJANGO简单测试实例
- asp.net截屏功能实现截取web页面
- PHP文件操作详解
- 数据库中使用正则表达式小结
- 深入理解Javascript中的循环优化
- JS下拉框内容左右移动效果的具体实现
- 微信js-sdk界面操作接口用法示例
- js变量作用域及可访问性的探讨
- 存取flex屏幕快照
- MongoDB中ObjectId的误区及引起的一系列问题
- python实现ip查询示例
- bgsound 背景音乐 的一些常用方法及特殊用法小结
- 解决vuex刷新状态初始化的方法实现
- Go语言init函数详解
- pygame实现俄罗斯方块游戏(基础篇2)
- Go语言学习技巧之命名规范
- Pytorch提取模型特征向量保存至csv的例子