包的本质就是一个包含__init__.py文件的目录

在python3中,即使包下没有__init__.py文件,import 包仍然不会报错,而在python2中,包下一定要有该文件,否则import 包报错

凡是在导入时带点的,点的左边都必须是一个包

如果不想在导入模块时打很多点,可以添加路径:


# 查看可导入模块的路径:
print(sys.path)
# 添加路径
sys.path.append('路径')



__init__.py文件

不管是哪种方式,只要是第一次导入包或者是包的任何其他部分,都会依次执行包下的__init__.py文件(我们可以在每个包的文件内都打印一行内容来验证一下),这个文件可以为空,但是也可以存放一些初始化包的代码。

 

绝对导入和相对导入

绝对导入:直观,但是不能导入

相对导入:用.或者..的方式最为起始(只能在一个包中使用,不能用于不同目录内) 缺点:包里的模块如果想使用其它模块的内容只能使用相对路径,使用了相对路径就不能在包内直接执行了



在glance/api/version.py

#绝对导入
from glance.cmd import manage
manage.main()

#相对导入
from ..cmd import manage
manage.main(



 

软件开发规范



## start.py

import sys,os

BASE_DIR=os.path.dirname(os.path.dirname(os.path.abspath(__file__)))  # 获取上层目录
sys.path.append(BASE_DIR) # 将上层目录添加进解释器路径中

from core import core
from conf import my_log_settings

if __name__ == '__main__':
    my_log_settings.load_my_logging_cfg()
    core.run()



 

Python中导入heart模块失败 python导入包出错_Python中导入heart模块失败

bin ---开始文件 程序入口
conf ---配置文件
core ---程序核心代码
db ---数据文件
lib ---包 自己写的通用模块
log ---日志 记录

 

异常处理


错误:

语法错误

逻辑错误

常用异常

AttributeError 试图访问一个对象没有的树形,比如foo.x,但是foo没有属性x
IOError 输入/输出异常;基本上是无法打开文件
ImportError 无法引入模块或包;基本上是路径问题或名称错误
IndentationError 语法错误(的子类) ;代码没有正确对齐
IndexError 下标索引超出序列边界,比如当x只有三个元素,却试图访问x[5]
KeyError 试图访问字典里不存在的键
KeyboardInterrupt Ctrl+C被按下
NameError 使用一个还未被赋予对象的变量
SyntaxError Python代码非法,代码不能编译(个人认为这是语法错误,写错了)
TypeError 传入对象类型与要求的不符合
UnboundLocalError 试图访问一个还未被设置的局部变量,基本上是由于另有一个同名的全局变量,
导致你以为正在访问它
ValueError 传入一个调用者不期望的值,即使值的类型是正确的

使用try...except不中断程序

万能异常:Exception



try:
    print('1111')
    print('2222')
    ret = int(input('number >>>'))
    print(ret*'*')
except Exception as error:
    print('你错了,老铁',error)  # 如果错了,会给出异常信息



获取异常详细信息



try:
    res_bb = eval(funcName)
except:
    print('failed to execute {0} : {1}'.format(t, sys.exc_info()))



finally

finally和return相遇的时候 依然会执行



s1 = 'hello'
try:
    int(s1)
except IndexError as e:
    print(e)
except KeyError as e:
    print(e)
except ValueError as e:
    print(e)
#except Exception as e:
#    print(e)
else:
    print('try内代码块没有异常则执行我')
finally:
    print('无论异常与否,都会执行该模块,通常是进行清理工作')



自定义异常



class EvaException(BaseException):
    def __init__(self,msg):
        self.msg=msg
    def __str__(self):
        return self.msg

try:
    raise EvaException('类型错误')
except EvaException as e:
    print(e)



 

断言

assert 条件