datetime与logging

datetime模块

datetime是python处理时间和日期的标准库。

类名 功能说明
date 日期对象,常用的属性有year, month, day
time 时间对象hour,minute,second,毫秒
datetime 日期时间对象,常用的属性有year, month, day hour, minute, second, microsecond
timedelta 时间间隔,即两个时间点之间的长度
主要使用: datetime.datetiem( ) 、 datetime.timedelta( )

datetime类中常用方法

  1. 获取当前日期时间:
    datetime.now();
  2. 日期时间转化为时间戳:
    时间日期对象.timestamp()
  3. 时间戳转化为日期时间:
    datetime.fromtimestamp(时间戳)
  4. 日期时间对象转字符串:
    时间日期对象.strftime(format)
  5. 字符串转日期时间对象:
    datetime.strptime(data_str, format)

格式字符串常用格式

image.png
import datetime


#时间对象hour,minute,second,毫秒
time = datetime.time(23,59,10,100) #>>> 23:59:10.000100  #hour must be in 0..23 时分秒不能超过整的比如24时60分60秒
print(time) #>>> 23:59:10

#日期对象,常用的属性有year, month, day
date = datetime.date(2018,9,4)
print(date) #>>> 2018-09-04

#日期时间对象,常用的属性有year, month, day,hour, minute, second,
date2 = datetime.datetime(2018,9,4,23,59,10,100)
print(date2) #2018-09-04 23:59:10.000100


#获取当前日期时间
now = datetime.datetime.now()
print(now)  #2018-09-05 20:56:52.343908

#日期时间转化为时间戳:时间日期对象.timestamp();
date3 = datetime.datetime.now().timestamp() #1536152212.343971
print(date3)

#时间戳转化为日期时间:datetime.fromtimestamp(时间戳)
date4 = datetime.datetime.fromtimestamp(date3)
print(date4)  #2018-09-05 20:56:52.343971

#日期时间对象转字符串:时间日期对象.strftime(format)
date5 = datetime.datetime.now().strftime('%Y/%m/%d %I:%M:%S')
print(date5)  #2018/09/05 09:24:48

#字符串转日期时间对象:datetime.strptime(data_str, format)
result = datetime.datetime.strptime('2018-9-5-21-10', '%Y-%m-%d-%H-%M') #两个格式要对应:日期天数对应,格式前后对应
print(result) #2018-09-05 21:10:00

#timedelta时间间隔,即两个时间点之间的长度
'''
datetime.timedelta( days=0,seconds=0, microseconds=0 milliseconds=0,
                                       minutes=0, hours=0, weeks=0 )
'''

now = datetime.datetime.now()
print(now) #2018-09-05 21:12:32.241446

#获取明天日期
tomorrow = now + datetime.timedelta(days=1)
print(tomorrow) #2018-09-06 21:12:32.241446

#获得前1天日期
before1 = now - datetime.timedelta(days=1)
print(before1) #2018-09-04 21:12:32.241446

print(before1-tomorrow) #-2 days, 0:00:00  两个日期时间可以相减,不可相加乘
print(tomorrow-before1) #2 days, 0:00:00

logging模块

image.png

日志等级

  • Logging 中几种级别:DEBUG < INFO < WARNING < ERROR < CRITICAL
日志等级(level) 描述
DEBUG 调试信息,通常在诊断问题的时候用得着
INFO 普通信息,确认程序按照预期运行
WARNING 警告信息,表示发生意想不到的事情,或者指示接下来可能会出现一些问题,但是程序还是继续运行
ERROR 错误信息,程序运行中出现了一些问题,程序某些功能不能执行
CRITICAL 严重的错误,导致程序无法继续运行

Formatter格式

%(asctime)s 日志事件发生的时间
%(levelname)s 该日志记录的日志级别
%(message)s 日志记录的文本内容
%(name)s 所使用的日志器名称,默认是'root'
%(pathname)s 调用日志记录函数的文件的全路径
%(filename)s 调用日志记录函数的文件
%(funcName)s 调用日志记录函数的函数名
%(lineno)d 调用日志记录函数的代码所在的行号

import logging

message = '错误信息日志'


LOG_FORMAT = "%(asctime)s-%(levelname)s-%(message)s-%(lineno)d"  #设置输出的格式
#对logger进行配置,设置日志级别与格式化
logging.basicConfig(level=logging.WARNING, format=LOG_FORMAT)

#Logging 中几种级别:DEBUG < INFO < WARNING < ERROR < CRITICAL
#如果把looger的级别设置为WARNING, 那么小于WARNING级别的日志都不输出, 大于等于WARNING级别的日志都输出
logging.debug("this is debug log")
logging.info("this is info log")
logging.warning("this is warning log")
logging.error("this is error log")
logging.critical("this is critical log")

输出:
2018-09-05 23:57:28,359-WARNING-this is warning log-74
2018-09-05 23:57:28,359-ERROR-this is error log-75
2018-09-05 23:57:28,359-CRITICAL-this is critical log-76

如果我们简单的使用logging可以使用以上方法,如果需要更深入的使用,则需要定制,logging模块提供了模块化组件的方法,来灵活配置日志器。

组件 说明
Loggers(日志记录器) 提供程序直接使用的接口
Handlers(日志处理器) 将记录的日志发送到指定的位置
Filters(日志过滤器) 用于过滤特定的日志记录
Formatters(日志格式器) 用于控制日志信息的输出格式
模块化组件使用步骤:

1.创建一个logger(日志处理器)对象

logger_1 = logging.getLogger('logg1') #创建了一个日志记录器

2.定义handler(日志处理器),决定把日志发到哪里
常用的是:
StreamHandler-》输出到控制台
FileHandler-》输出到文件

fh = logging.FileHandler('test.log', mode='a') #把日志发送到文件中去
#输出到控制台的handler
ch = logging.StreamHandler()

3.设置日志级别(level)和输出格式Formatters(日志格式器)

logger_1.setLevel(logging.DEBUG) #设置日志等级

#(时间,文件名,出错行数, 等级, 内容)
formater = logging.Formatter("%(asctime)s - %(filename)s [line:%(lineno)d] - %(levelname)s: %(message)s")#第二个参数时间格式化
fh.setFormatter(formater) #把格式器应用到handler中去

4.把handler添加到对应的logger中去

logger_1.addHandler(fh)
logger_1.addHandler(ch)

# 第一步,创建一个logger
logger_1 = logging.getLogger('logg1') #创建了一个日志记录器

# 第二步,创建一个handler,用于写入日志文件
fh = logging.FileHandler('test.log', mode='a') #定义一个handles,把日志发送到文件中去
#输出到控制台的handler
ch = logging.StreamHandler()

#第三步,定义handler的输出格式
#(时间,文件名,出错行数, 等级, 内容)
formater = logging.Formatter("%(asctime)s - %(filename)s [line:%(lineno)d] - %(levelname)s: %(message)s")#第二个参数时间格式化
fh.setFormatter(formater) #把格式器应用到handler中去
logger_1.setLevel(logging.DEBUG) #设置日志等级

#第四步,将对应的hangler添加在logger对象中
logger_1.addHandler(fh)
logger_1.addHandler(ch)

输出:
[Errno 2] No such file or directory: 'test.txt'
No such file or directory
2018-09-05 23:57:28,360-WARNING-No such file or directory-104

练习

1.写一个程序能接收用户输入出生日期从而计算出用户活了多久。

from datetime import datetime
birthday = input('请输入您的出生日期,格式如:2018-09-06 13:10:12 =>>')

try:
    #字符串转换日期时间对象
    birthday = datetime.strptime(birthday, '%Y-%m-%d %H:%M:%S')
    print(birthday)
    now = datetime.now()
    print(now)

    live_time = now - birthday
    print(live_time)
    print('您已在地球生存{}天+{}秒'.format(live_time.days, live_time.seconds))
except Exception as e:
    print('日期格式不正确,请按照格式如:2018-09-06 13:10:12 输入,谢谢!')

格式正确:


image.png

格式错误:


image.png

2.使用logging模块化组件实现能记录错误信息到文件的程序,并在程序里制造错误,看错误信息是否被记录下来;

import logging
#创建日志器
logger = logging.getLogger('%s_log'%__name__)
#定义handler(日志处理器),决定把日志发到哪里
file_handler = logging.FileHandler('test.log', 'a') #写入文件
console_handler = logging.StreamHandler()  #输出控制台
#设置日志级别(level)和输出格式Formatters(日志格式器)
#(时间,文件名,出错行数, 等级, 内容)
formater = logging.Formatter("%(asctime)s - %(filename)s [line:%(lineno)d] - %(levelname)s: %(message)s")#第二个参数时间格式化
file_handler.setFormatter(formater) #把格式器应用到handler中去
console_handler.setFormatter(formater) #把格式器应用到handler中去
#设置日志等级
#DEBUG < INFO < WARNING < ERROR < CRITICAL
logger.setLevel(logging.DEBUG)  #DEBUG以上都输出
#把handler添加到对应的logger中去
logger.addHandler(file_handler)
logger.addHandler(console_handler)
try:
    with open('test.txt', 'r') as f:
        print(f.read())
except FileNotFoundError as e:
    print(e)
    logger.warning('No such file or directory')

控制台输出:


image.png

写入文件:


image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,126评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,254评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,445评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,185评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,178评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,970评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,276评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,927评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,400评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,883评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,997评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,646评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,213评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,204评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,423评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,423评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,722评论 2 345

推荐阅读更多精彩内容

  • From:Python之日志处理(logging模块) - 云游道士 - 博客园 https://www.cnbl...
    vigny的先生阅读 2,672评论 3 5
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,599评论 18 139
  • 写在前面的话 代码中的# > 表示的是输出结果 输入 使用input()函数 用法 注意input函数输出的均是字...
    FlyingLittlePG阅读 2,730评论 0 8
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,499评论 25 707
  • 周末很热没有可以乘凉的地方,下午老公说钓鱼处有风,可乘凉,无事可做就跟着吧,消遣一下。 到的时候,...
    魅力格桑阅读 79评论 0 0