发布于2019-08-05 11:12 阅读(1203) 评论(0) 点赞(1) 收藏(0)
包:文件夹下具有__init__.py文件就是一个包,包用来管理多个模块
包的结构如下:
bake
├── __init__.py
├── api
├── __init__.py
├── policy.py
└── versions.py
├── cmd
├── __init__.py
└── manage.py
└── db
├── __init__.py
└── models.py
在bake的同级创建一个test.py导入policy.py:
import bake.api.policy
bake.api.policy.get()
#导入的名字太长了,可以起别名
import bake.api.policy as p
p.get()
#from 导入在__init__.py修改
from . import policy
#我们需要在policy文件中向sys.path添加了当前的路径
import os
import sys
sys.path.insert(os.path.dirname(__file__))
#print(__file__)查看一下
#使用__all__,在__init__.py中
__all__ = ["policy"]
#或
from . import policy
总结:
import 包.包.包
from 包.包.包 import 模块
路径:
绝对:从在外层开始导入
相对:从当前开始(.)导入或者从父级(..)导入
使用相对路径时必须在包的最外层且同级
from 包 import *
需要在__init__.py做操作
python2:import文件夹(没有__init__.py)会报错
python3:import文件夹(没有__init__.py)不会报错
logging模块用于记录软件的各种状态,交易记录,错误记录,登录记录……
import logging
logging.debug('debug message')
logging.info('info message')
logging.warning('warning message')
logging.error('error message')
logging.critical('critical message')
默认情况下python的logging模块将日志打印到了标准输出中,且只显示了大于等于WARNING级别的日志,证明默认的级别为WARNING
日志级别:CRITICAL > ERROR > WARNING > INFO > DEBUG
只能写入日志,不能公屏输出
import logging
logging.basicConfig(level = logging.DEBUG,
format = '%(astime)s %(filename)s [line:%(lineno)d] %(levelname)s %(message)s',
datefmt = '%Y-%m-%d %H:%M:%S',
filename = 'test.log',
filemode = 'a')
dic = {"key":123}
logging.debug(dic)
num = 100
logging.info(f"用户余额:{num - 50}")
try:
num = int(input("请输入数字:"))
except Exception as e:
logging.warning("e")
logging.error('error message')
logging.critical('critical message')
basicConfig()函数中可通过具体参数来更改logging模块默认行为,可用参数有:
format参数中可能用到的格式化串:
import logging
logger = logging.getLogger()
# 创建一个logger
fh = logging.FileHandler('test.log',mode="a",encoding='utf-8') # 文件
ch = logging.StreamHandler() # 屏幕
formatter = logging.Formatter('%(asctime)s - %(name)s - %(filename)s - [line:%(lineno)d] - %(levelname)s - %(message)s')
# 将屏幕和文件都是用以上格式
logger.setLevel(logging.DEBUG)
# 设置记录级别
fh.setFormatter(formatter)
# 使用自定义的格式化内容
ch.setFormatter(formatter)
logger.addHandler(fh) #logger对象可以添加多个fh和ch对象
logger.addHandler(ch)
logger.debug('logger debug message')
logger.info('logger info message')
logger.warning('logger warning message')
logger.error('logger error message')
logger.critical('logger critical message')
作者:sdhjsdh
链接:https://www.pythonheidong.com/blog/article/4248/fbc620872ab1536bc68d/
来源:python黑洞网
任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任
昵称:
评论内容:(最多支持255个字符)
---无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事,而不是让内心的烦躁、焦虑,坏掉你本来就不多的热情和定力
Copyright © 2018-2021 python黑洞网 All Rights Reserved 版权所有,并保留所有权利。 京ICP备18063182号-1
投诉与举报,广告合作请联系vgs_info@163.com或QQ3083709327
免责声明:网站文章均由用户上传,仅供读者学习交流使用,禁止用做商业用途。若文章涉及色情,反动,侵权等违法信息,请向我们举报,一经核实我们会立即删除!