包的使用
1.首次导入模块发生的事情3件事情
先产生一个执行文件的名称空间:
1.创建模块文件的名称空间
2.执行模块文件中的代码 将产生的名字放入模块的名称空间中
3.在执行文件中拿到一个指向模块名称空间的名字
2.什么是包?
3.首次导入包发生的事情
首次导入包:
先产生一个执行文件的名称空间
1.创建包下面的__init__.py文件的名称空间
2.执行包下面的__init__.py文件中的代码 将产生的名字放入包下面的__init__.py文件名称空间中
3.在执行文件中拿到一个指向包下面的__init__.py文件名称空间的名字
4.为什么要有包?
模块的第一个版本只有10个功能,但是未来在扩展版本的时候,模块名和用法应该最好不要去修改,但是这只是对使用者友好,而由于版本扩展,文件越来越大,模块设计者对模块的管理、维护会越来越复杂,因此我们可以使用包来扩展模块的功能。
5.python2和Python3中导入包注意事项
当你在删程序不必要的文件的时候 千万不要随意删除__init__.py文件
包 == 模块, 包拿来导入用的
包是含有__init__.py的文件夹; 导包就是导入__init__
''' 包一定是被当作模块文件导入,模块文件 m1.py/m2.py 的搜索路径以执行文件 包的介绍.py 路径为准,在执行文件所在的文件夹只能看到包aaa,而找不到包aaa内的m1.py文件。 ''' #包 ##aaa ###__init__.py from m1 import f1 ###m1.py def f1(): print('来自m1中的f1') ##包的介绍.py(执行文件) import aaa print(aaa.f1) ''' 打印结果 ModuleNotFoundError: No module named 'm1' '''
#正确的导包的方式,绝对导入(一层包) #包 ##包的介绍.py(执行文件) import aaa #包aaa print(aaa.f1) print(aaa.f2) ###__init__.py # 包aaa内文件 from aaa.m1 import f1 # 不符合包的原则 from aaa.m1 import f2 # 不符合包的原则 ###m1.py # 包aaa内文件 def f1(): print('来自m1中的f1') def f2(): print('来自m1中的f2') ''' <function f1 at 0x000000000BC94F28> <function f2 at 0x000000000BCA7048> '''
#正确的导包的方式,绝对导入(二层包) #包 ##包的介绍.py(执行文件) import aaa #包aaa print(aaa.f5) print(aaa.f5()) ###__init__.py # 包aaa内文件 from aaa.bbb.m3 import f5 # 不符合包的原则 ###m1.py # 包aaa内文件 def f1(): print('来自m1中的f1') def f2(): print('来自m1中的f2') ###包bbb ####__init__.py #包bbb内的文件 pass ####m3.py # #包bbb内的文件 def f5(): print('来自m3中的f5') def f6(): print('来自m3中的f6') ''' <function f5 at 0x0000000009FF3F28> 来自m3中的f5 ''' 或者直接可以在执行文件内还是以绝对导入的方式导入f5也是一样的。 from aaa.bbb.m3 import f5 print(f5) print(f5())
5.相对导入 和绝对导入
绝对导入:必须以执行文件的搜索路径为基准,比如上面的from aaa.bbb.m3 import f5
相对导入:
5.1相对导入引入事例
5.2相对导入(练习)
#正确的导包的方式,相对导入(二层包) #包 ##包的介绍.py(执行文件) import aaa #包aaa print(aaa.f5) print(aaa.f5()) ###__init__.py # 包aaa内文件 from aaa.bbb import f5 ###m1.py # 包aaa内文件 def f1(): print('来自m1中的f1') def f2(): print('来自m1中的f2') ###包bbb ####__init__.py #包bbb内的文件 from .m3 import f5 ####m3.py # #包bbb内的文件 def f5(): print('来自m3中的f5') def f6(): print('来自m3中的f6') ''' <function f5 at 0x000000000A008048> 来自m3
6.导包注意事项
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍PDO防注入原理分析以及注意事项,包括了PDO防注入原理分析以及注意事项的使用技巧和注意事项,需要的朋友参考一下 我们都知道,只要合理正确使用PDO,可以基本上防止SQL注入的产生,本文主要回答以下两个问题: 为什么要使用PDO而不是mysql_connect? 为何PDO能防注入? 使用PDO防注入的时候应该特别注意什么? 一、为何要优先使用PDO? PHP手册上说得很清楚:
一、在线机器人相关限制及注意事项 1.1 术语说明 原生渠道:包含微信公众号、微信小程序、企业微信、微博等。原生渠道的特征是,对话发生在这些渠道的原生界面中,我们无法定义诸如对接参数、界面样式、功能按钮、聊天消息交互等内容,功能会受到限制。 1.2 功能限制 1.2.1 原生渠道自带转人工强制词 原生渠道自带转人工强制词,无需配置、默认生效(区别于「转人工关键词」)。客户一旦发送「转人工」「人工」
文件为空。我正在运行Python2.7.1。 运行会导致。 类似问题:关于相对python导入的最终答案,如何在python中进行相对导入?,在python中进行相对导入
根据这个答案,您可以使用来使用类似这样的相对导入: 为什么相对导入不适用于sklearn。特征提取。文本 我验证了是一个具有以下功能的模块: 编辑 “不工作”,我的意思是它不导入模块。 我正在使用Python 3.4 绝对方式工作: 相对方式不:
全局 如果用户在使用ddl/dml 操作时 管理员赋予了新的上级审核人 如需获取新审核人 必须点击重置按钮重新获取 由于脱敏,limit限制基于语法树解析。查询功能并不保证100%支持所有mysql语句,对于一些复杂且使用较多函数的查询请在测试后使用。
本文向大家介绍ThinkPHP入口文件设置及相关注意事项分析,包括了ThinkPHP入口文件设置及相关注意事项分析的使用技巧和注意事项,需要的朋友参考一下 本文实例分析了ThinkPHP入口文件设置及相关注意事项。分享给大家供大家参考。具体如下: 希望本文所述对大家基于ThinkPHP框架的PHP程序设计有所帮助。