1. 包

文件夹下具有__init__.py文件就是一个包
from bake.cmd import manage
manage.get() # 绝对路径 从最外层的包开始导入 from .. cmd manage import get
get()
# 相对路径 从当前(.)开始导入或者父级(..)导入,使用相对路径导入时必须在包的最外层且同级进行导入
python2中import包,如果没有__init__.py就是报错
python3中包里没有__init__.py文件不会报错,不能用*方法
使用 from bake import * 时
必须在同级的__init__.py文件中,写
__all__=["文件名"] 或者 from . import "文件名"
__file__  # 当前文件的绝对路径,不会变动
import os
import sys
sys.path.insert(0,os.path.dirname(__file__)

2. logging 日志

应用场景:错误日志、交易记录、消费记录

2.1 日志级别

import logging
logging.debug('debug message')
logging.info('info message')
logging.warning('warning message')
logging.error('error message')
logging.critical('critical message') # 日志级别等级CRITICAL > ERROR > WARNING > INFO > DEBUG
# 默认的日志级别设置为WARNING

2.2 配置日志格式:

import logging
logging.basicConfig(level=logging.DEBUG,
format='%(asctime)s %(filename)s [line:%(lineno)d] %(levelname)s %(message)s',
datefmt='%Y-%m-%d %H:%M:%S',
filename='test.log',
filemode='a'
# 参数
•filename:用指定的文件名创建FiledHandler,这样日志会被存储在指定的文件中。
•filemode:文件打开方式,在指定了filename时使用这个参数,默认值为“a”还可指定为“w”。
•format:指定handler使用的日志显示格式。
•datefmt:指定日期时间格式。
•level:设置记录日志的级别
•stream:用指定的stream创建StreamHandler。可以指定输出到
•sys.stderr,sys.stdout或者文件(f=open(‘test.log’,’w’)),默认为sys.stderr。若同时列出了filename和stream两个参数,则stream参数会被忽略。
# format参数可能用到的字符串
•%(name)s Logger的名字
•%(levelno)s 数字形式的日志级别
•%(levelname)s 文本形式的日志级别
•%(pathname)s 调用日志输出函数的模块的完整路径名,可能没有
•%(filename)s 调用日志输出函数的模块的文件名
•%(module)s 调用日志输出函数的模块名
•%(funcName)s 调用日志输出函数的函数名
•%(lineno)d 调用日志输出函数的语句所在的代码行
•%(created)f 当前时间,用UNIX标准的表示时间的浮 点数表示
•%(relativeCreated)d 输出日志信息时的,自Logger创建以 来的毫秒数
•%(asctime)s 字符串形式的当前时间。默认格式是 “2003-07-08 16:49:45,896”。逗号后面的是毫秒
•%(thread)d 线程ID。可能没有
•%(threadName)s 线程名。可能没有
•%(process)d 进程ID。可能没有
•%(message)s用户输出的消息

2.3 logger 对象配置

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')

python 19 包的更多相关文章

  1. 想拥有自己的Python程序包,你只需15步

    来源商业新知网,原标题:15步,你就能拥有自己的Python程序包 全文共 3192 字,预计学习时长 6 分钟 每个软件开发员和数据科学家都难免要做程序包.本文推荐一篇 Python开源程序包的制作 ...

  2. Python中包(package)的调用方式

     一.什么是Python Package 如何区分你看到的目录是一个Python Package包呢?其实很简单,你只要看这个名录下是否有“__init__.py”这个文件就好了,如果有那么就是Pyt ...

  3. Python的包管理工具

    Python的包管理工具 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.为什么使用包管理 Python的模块或者源文件直接可以复制到目标项目目录中,就可以导入使用了. 但是为了 ...

  4. Python PIP包管理器

    版权所有,未经许可,禁止转载 章节 Python 介绍 Python 开发环境搭建 Python 语法 Python 变量 Python 数值类型 Python 类型转换 Python 字符串(Str ...

  5. 机器学习常用Python扩展包

    在Ubuntu下安装Python模块通常有3种方法:1)使用apt-get:2)使用pip命令(推荐);3)easy_instal 可安装方法参考:[转]linux和windows下安装python集 ...

  6. Python的包管理工具Pip (zz )

    Python的包管理工具Pip 接触了Ruby,发现它有个包管理工具RubyGem很好用,并且有很完备的文档系统http://rdoc.info 发现Python下也有同样的工具,包括easy_ins ...

  7. 简易安装python统计包

    PythonCharm简易安装python统计包及 本文介绍使用pythonCharm IDE 来安装Python统计包或一些packages的简单过程,基本无任何技术难度,顺便提一提笔者在安装过程中 ...

  8. 安装python 的 包 paramiko

    安装python 的 包 paramiko 安装 依赖 yum -y install gcc python-devel 获取安装 pycryptowget https://pypi.python.or ...

  9. python的包和模块

    python 的包即文件夹,但是必须包含_init_.py 模块就是xx.py

随机推荐

  1. javascript基础学习第三天

    ☞ 命名法: 小驼峰命名法 和 大驼峰命名法(帕斯卡命名法) 变量命名规则:遵循小驼峰命名法 [变量名第一个字母小写后面每一个单词的首字母大写] var userNameAge; 函数命名规则:遵循帕 ...

  2. get解决乱码的方式

    //自定义的解决乱码方式

  3. Java多线程笔记总结

    1.线程的三种创建方式 对比三种方式: 通过继承Thread类实现 通过实现Runnable接口 实现Callable接口 第1种方式无法继承其他类,第2,3种可以继承其他类: 第2,3种方式多线程可 ...

  4. bean的创建(五)第一部分

    AbstractBeanFactory.doGetBean protected <T> T doGetBean( final String name, final Class<T&g ...

  5. spring解析配置文件(三)

    一.从XmlBeanDefinitionReader的registerBeanDefinitions(doc,resource)开始 protected int doLoadBeanDefinitio ...

  6. BFS vs DFS

    1 Clone Graph   1  copy ervery nodes by bfs  2  add neighbors public UndirectedGraphNode cloneGraph( ...

  7. Python3数据驱动ddt

    对于同一个方法执行大量数据的程序时,我们可以采用ddt数据驱动的方式,来对数据规范化整理及输出 一.需要使用python的ddt库,ddt,data,unpack方法 1.仅使用ddt和data,代码 ...

  8. Linux零拷贝技术,看完这篇文章就懂了

    本文首发于我的公众号 Linux云计算网络(id: cloud_dev),专注于干货分享,号内有 10T 书籍和视频资源,后台回复 「1024」 即可领取,欢迎大家关注,二维码文末可以扫. 本文讲解 ...

  9. codeforces 327 B. Hungry Sequence

    题目链接 题目就是让你输出n个数的序列,要保证该序列是递增的,并且第i个数的前面不能保护它的约数,我直接先对前100000的素数打表,然后输出前n个,so easy. //cf 191 B #incl ...

  10. python 实现两个文本文件内容去重

    实现两个文本内容去重,输出两个文本不重复的结果 两个测试文本内容如下 1.txt中内容为 1 2 3 4 5 6 7 8 2.txt中内容为 1 2 3 4 5 6 7 8 9 10 11 12 13 ...