Python中关于使用模块的基础知识
一个模块可以在逻辑上组织Python代码。将相关的代码到一个模块中,使代码更容易理解和使用。模块是可以绑定和借鉴任意命名属性的Python对象。
简单地说,一个模块是由Python代码的文件。一个模块可以定义函数,类和变量。模块还可以包括可运行的代码。
例子:
Python代码的模块名为aname通常位于一个名为aname.py。下面是一个简单的模块,support.py作为例子
def print_func( par ): print "Hello : ", par return
import语句:
可以通过在其他一些Python源文件执行import语句来使用任何Python源文件作为一个模块。import的语法如下:
import module1[, module2[,... moduleN]
当解释器遇到import语句,它导入(import)模块如果模块出现在搜索路径。搜索路径是一个目录列表,该解释器导入模块之前搜索。例如,导入模块hello.py,需要把下面的命令在脚本的顶部:
#!/usr/bin/python # Import module support import support # Now you can call defined function that module as follows support.print_func("Zara")
当执行上面的代码,产生以下结果:
Hello : Zara
一个模块被加载一次,不管导入的次数。这可防止模块执行发生多次导入。
from...import 语句
Python的from语句可以从一个模块中导入特定的属性到当前的命名空间。from...import 语法如下:
from modname import name1[, name2[, ... nameN]]
例如,从模块fib导入函数fibonacci,使用下面的语句:
from fib import fibonacci
此语句不导入整个模块fib到当前的命名空间;它只是介绍了fibonacci从模块fib导入模块的全局符号表列。
from...import * 语句:
它也可以通过使用下面的import语句导入从模块到当前的命名空间的所有名称:
from modname import *
这提供了导入从模块到当前的命名空间中的所有项目一个简单的方法;不过,这个语句应谨慎使用。
定位模块:
当导入一个模块,在下列序列模块由Python解释器搜索:
- 当前目录
- 如果未找到该模块,然后Python搜索在shell变量PYTHONPATH每个目录
- 如果这些方法都失败,Python会检查默认路径。在UNIX上,默认路径是正常是/usr/local/lib/python/
模块搜索路径被存储在系统模块sys作为所述的sys.path变量。在sys.path的变量包含当前目录,PYTHONPATH和相关的默认安装。
PYTHONPATH变量:
在PYTHONPATH是一个环境变量,包括目录列表中。 PYTHONPATH的语法shell变量PATH相同。
下面是Windows系统的典型PYTHONPATH:
set PYTHONPATH=c:\python20\lib;
这里是UNIX系统的典型PYTHONPATH:
set PYTHONPATH=/usr/local/lib/python
命名空间和作用域:
变量名称(标识)映射到对象。名称空间是变量名(键)及其相应的对象(的值)的字典。
Python语句可以在本地命名空间和全局命名空间访问变量。如果局部和全局变量同名,局部变量屏蔽全局变量。
每个函数都有自己的命名空间。类方法遵循相同的作用域规则为普通函数。
Python对变量是否为局部或全局进行假定猜测。它假定任何变量赋值函数中的值是局部的。
因此为了使一个函数内的值赋给一个全局变量,必须先使用global语句。
声明 global VarName 告诉Python VarName是一个全局变量。Python 停止寻找该变量的局部命名空间。
例如,我们在全局命名空间中定义的变量Money 。在该函数的Money ,我们给定Money 的值,因此Python 假定Money 为局部变量。但是,我们设定它,所以一个UnboundLocalError是结果之前访问的局部变量Money 的值。取消global语句解决了这个问题。
#!/usr/bin/python Money = 2000 def AddMoney(): # Uncomment the following line to fix the code: # global Money Money = Money + 1 print Money AddMoney() print Money
dir( ) 函数:
使用dir()内置函数返回一个包含一个模块中定义名称的字符串的排序列表。
该列表包含在一个模块中定义的所有模块,变量和函数的名称。下面是一个简单的例子:
#!/usr/bin/python # Import built-in module math import math content = dir(math) print content; 当执行上面的代码,产生以下结果: ['__doc__', '__file__', '__name__', 'acos', 'asin', 'atan', 'atan2', 'ceil', 'cos', 'cosh', 'degrees', 'e', 'exp', 'fabs', 'floor', 'fmod', 'frexp', 'hypot', 'ldexp', 'log', 'log10', 'modf', 'pi', 'pow', 'radians', 'sin', 'sinh', 'sqrt', 'tan', 'tanh']
在这里,特殊字符串变量__name__是模块的名称,__file__是从中加载的模块的文件名。
globals()和 locals()函数:
globals() 和 locals() 函数可用于返回在根据在它们被称为位置的全局和局部名称空间的名称。
如果locals()被一个函数中调用时,它会返回所有可以在局部从函数访问的名称。
如果globals()从一个函数中调用时,它会返回所有可以从全局函数进行访问的名称。
这两个函数的返回类型是字典。因此,名称可以使用keys()函数提取出来。
reload()函数:
当该模块被导入到一个脚本,在一个模块的顶层部分的代码只执行一次。
因此,如果你想重新执行的顶级代码模块中,可以使用reload()函数。reload()函数导入先前导入的模块了。reload()函数的语法是这样的:
reload(module_name)
在这里,module_name是要重装,不包含模块名字符串的模块的名称。例如,要重新加载hello模块,请执行以下操作:
reload(hello)
Python中的包:
包是用于定义由模块和子包和子子包等的单一的Python应用环境的分层文件目录结构。
考虑一个文件Pots.py在Phone目录中可用。此文件的源代码如下一行:
#!/usr/bin/python def Pots(): print "I'm Pots Phone"
类似的方法,我们具有不同功能的另两个文件具有相同的名称如上:
- Phone/Isdn.py文件有函数 Isdn()
- Phone/G3.py 文件有函数 G3()
现在,创建在Phone目录中多了一个文件__init__.py:
Phone/__init__.py
为了让所有的功能可用,当导入Phone,需要把__init__.py明确的import语句如下:
from Pots import Pots from Isdn import Isdn from G3 import G3
当添加完这些行到__init__.py,那么已经导入了Phone包所有这些类的使用。
#!/usr/bin/python # Now import your Phone Package. import Phone Phone.Pots() Phone.Isdn() Phone.G3()
当执行上面的代码,产生以下结果:
I'm Pots Phone I'm 3G Phone I'm ISDN Phone
在上面的例子我们采取示例每个文件单个函数,但可以保留文件中多个函数。还可以在这些文件定义不同的Python类,可以在包外创建那些类。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

MySQL 有免费的社区版和收费的企业版。社区版可免费使用和修改,但支持有限,适合稳定性要求不高、技术能力强的应用。企业版提供全面商业支持,适合需要稳定可靠、高性能数据库且愿意为支持买单的应用。选择版本时考虑的因素包括应用关键性、预算和技术技能。没有完美的选项,只有最合适的方案,需根据具体情况谨慎选择。

文章介绍了MySQL数据库的上手操作。首先,需安装MySQL客户端,如MySQLWorkbench或命令行客户端。1.使用mysql-uroot-p命令连接服务器,并使用root账户密码登录;2.使用CREATEDATABASE创建数据库,USE选择数据库;3.使用CREATETABLE创建表,定义字段及数据类型;4.使用INSERTINTO插入数据,SELECT查询数据,UPDATE更新数据,DELETE删除数据。熟练掌握这些步骤,并学习处理常见问题和优化数据库性能,才能高效使用MySQL。

MySQL安装失败的原因主要有:1.权限问题,需以管理员身份运行或使用sudo命令;2.依赖项缺失,需安装相关开发包;3.端口冲突,需关闭占用3306端口的程序或修改配置文件;4.安装包损坏,需重新下载并验证完整性;5.环境变量配置错误,需根据操作系统正确配置环境变量。解决这些问题,仔细检查每个步骤,就能顺利安装MySQL。

MySQL下载文件损坏,咋整?哎,下载个MySQL都能遇到文件损坏,这年头真是不容易啊!这篇文章就来聊聊怎么解决这个问题,让大家少走弯路。读完之后,你不仅能修复损坏的MySQL安装包,还能对下载和安装过程有更深入的理解,避免以后再踩坑。先说说为啥下载文件会损坏这原因可多了去了,网络问题是罪魁祸首,下载过程中断、网络不稳定都可能导致文件损坏。还有就是下载源本身的问题,服务器文件本身就坏了,你下载下来当然也是坏的。另外,一些杀毒软件过度“热情”的扫描也可能造成文件损坏。诊断问题:确定文件是否真的损坏

MySQL 可在无需网络连接的情况下运行,进行基本的数据存储和管理。但是,对于与其他系统交互、远程访问或使用高级功能(如复制和集群)的情况,则需要网络连接。此外,安全措施(如防火墙)、性能优化(选择合适的网络连接)和数据备份对于连接到互联网的 MySQL 数据库至关重要。

MySQL数据库性能优化指南在资源密集型应用中,MySQL数据库扮演着至关重要的角色,负责管理海量事务。然而,随着应用规模的扩大,数据库性能瓶颈往往成为制约因素。本文将探讨一系列行之有效的MySQL性能优化策略,确保您的应用在高负载下依然保持高效响应。我们将结合实际案例,深入讲解索引、查询优化、数据库设计以及缓存等关键技术。1.数据库架构设计优化合理的数据库架构是MySQL性能优化的基石。以下是一些核心原则:选择合适的数据类型选择最小的、符合需求的数据类型,既能节省存储空间,又能提升数据处理速度

MySQL拒启动?别慌,咱来排查!很多朋友安装完MySQL后,发现服务死活启动不了,心里那个急啊!别急,这篇文章带你从容应对,揪出幕后黑手!读完后,你不仅能解决这个问题,还能提升对MySQL服务的理解,以及排查问题的思路,成为一名更强大的数据库管理员!MySQL服务启动失败,原因五花八门,从简单的配置错误到复杂的系统问题都有可能。咱们先从最常见的几个方面入手。基础知识:服务启动流程简述MySQL服务启动,简单来说,就是操作系统加载MySQL相关的文件,然后启动MySQL守护进程。这其中涉及到配置

MySQL性能优化需从安装配置、索引及查询优化、监控与调优三个方面入手。1.安装后需根据服务器配置调整my.cnf文件,例如innodb_buffer_pool_size参数,并关闭query_cache_size;2.创建合适的索引,避免索引过多,并优化查询语句,例如使用EXPLAIN命令分析执行计划;3.利用MySQL自带监控工具(SHOWPROCESSLIST,SHOWSTATUS)监控数据库运行状况,定期备份和整理数据库。通过这些步骤,持续优化,才能提升MySQL数据库性能。
