08 datetime与logging模块(进阶)
datetime与logging模块
阶段一:日期与时间
1、datetime 模块中 主要类:
| 类名 | 功能说明 |
|---|---|
| date | 日期对象,常用的属性有year, month, day |
| time | 时间对象hour,minute,second,毫秒 |
| datetime | 日期时间对象,常用的属性有hour, minute, second, microsecond |
| timedelta | 时间间隔,即两个时间点之间的长度 |
日期: datetime.date( year, month, day )
时间: datetime.time( hour, minute, second,microsecond )
日期时间: datetime.datetime( year, month,day,hour, minute, second, microsecond )
时间间隔 : datetime.timedelta( days=0, seconds=0,microseconds=0, milliseconds=0,minutes=0, hours=0, weeks=0 )
2、datetime.datetime( ) 类中的常用方法:
1、now ():返回当前日期时间的datetime对象:
2、utcnow(…):返回当前日期时间的UTCdatetime对象
3.strptime(…):解析成datetime对象。根据string,format 2个参数,返回一个对应的datetime对象
例子: datetime.datetime.strptime(‘2018-3-22 15:28:18','%Y-%m-%d %H:%M:%S')
4.Strftime():格式化时间
例子:strtime=now.strftime("%Y-%m-%d %H:%M:%S")
5.时间戳转日期时间:t1= datetime.datetime.fromtimestamp(ts)
6日期时间转时间戳:t2=t1.timestamp()
3、时间运算 : ( 返回timedelte() 对象)
timedelta类是用来计算二个datetime对象的差值的。
此类中包含如下属性:
1、days:天数
2、microseconds:微秒数
3、seconds:秒数(>=0 并且 <1天)
4、total_seconds : 总秒数
4、例子
import datetime
# 日期
# date = datetime.date(2018,6,19)
# print(date)
# print(type(date))
# 时间 : : :
# t = datetime.time(10,50,30,1000)
# print(t)
# print(type(t))
# 日期时间
# dt = datetime.datetime(2018,6,19,10,55,30) # 日期必须要有,时间可以没有
# print(dt)
# print(type(dt))
# 时间间隔
# dlt = datetime.timedelta(hours=4)
# print(dlt)
# print(type(dlt))
# print(dt + dlt)
# 当前时间 东八区
# now = datetime.datetime.now()
# print(now)
# 格林威治时间
# utc = datetime.datetime.utcnow()
# print(utc)
# 北京时间,东八区时间
# delt = datetime.timedelta(hours=8)
# bei_jing = utc + delt
# print(bei_jing)
# 解析时间
# strp = datetime.datetime.strptime('jun-14-18 11:45','%b-%d-%y %H:%M')
# print(strp)
# 格式化时间
# strf = now.strftime('%Y-%m-%d %H:%M:%S')
# print(strf)
# 时间戳转换成日期时间
# t = datetime.datetime.fromtimestamp(0)
# print(t)
# 日期时间转换成时间戳
# t1 = t.timestamp()
# print(t1)
# 获取datetime对象中数据
now = datetime.datetime.now()
# print(now)
# 小时 分钟 秒钟
# print(now.hour)
# print(now.month)
# print(now.day)
# 星期
# print(now.weekday()) # 范围0-6
# print(now.isoweekday()) # 范围1-7
# iso标准化日期 isocalendar(...) # year年份,week number 周数,weekday星期
# a = now.isocalendar()
# year = now.isocalendar()[0]
# weekNum = now.isocalendar()[1]
# weekdaY = now.isocalendar()[2]
# print(a)
# print(year)
# print(weekNum)
# print(weekdaY)
# 计算你出生了多久
def how_long(year,month,day,hour=0,minut=0,second=0):
return datetime.datetime.now() - datetime.datetime(year,month,day,hour,minut,second)
a = how_long(1997,9,3)
print(a)
阶段二:logging模块
1、logging用法
1.初始化 logger = logging.getLogger(“name")
2.设置级别 logger.setLevel(logging.DEBUG),Logging中有NOTSET < DEBUG < INFO <WARNING < ERROR < CRITICAL这几种级别,日志会记录设置级别以上的日志
3.定义Handler,常用的是StreamHandler和FileHandler,
StreamHandler:将日志在控制台输出
FileHandler: 将日志记录到文件里面
4.formatter,定义了log信息的 内容 和格式,
例如:'%(asctime)s %(message)s', '%Y-%m-%d %H:%M:%S'
2、logging 中几种级别
NOTSET < DEBUG < INFO < WARNING< ERROR < CRITICAL
| 级别 | 何时使用 |
|---|---|
| DEBUG | 详细信息,典型地调试问题时会感兴趣 |
| INFO | 证明事情按照预期工作 |
| WARNING | 表明发生了一些意外,或者不久的将来会发生问题(如‘磁盘满了’)软件还是在正常工作 |
| ERROR | 由于更严重的问题,软件已不能执行一些功能了 |
| CRITICAL | 严重错误,表明软件已不能继续运行了 |
3、Formatter 中已有格式
%(name)s Logger的名字
%(levelname)s 文本形式的日志级别
%(message)s 用户输出的消息
%(asctime)s 字符串形式的当前时间。默认格式是“2003-07-08 16:49:45,896”。逗号后面的是毫秒
%(levelno)s 数字形式的日志级别
%(pathname)s 调用日志输出函数的模块的完整路径名,可能没有
%(filename)s 调用日志输出函数的模块的文件名
%(module)s 调用日志输出函数的模块名
%(funcName)s 调用日志输出函数的函数名
%(lineno)d 调用日志输出函数的语句所在的代码行
%(created)f 当前时间,用UNIX标准的表示时间的浮点数表示
%(relativeCreated)d 输出日志信息时的,自Logger创建以来的毫秒数
%(thread)d 线程ID。可能没有
%(threadName)s 线程名。可能没有
%(process)d 进程ID。可能没有
4、logging编程范式
import logging
# 1.初始化,实例化的过程
logger = logging.getLogger('test_log')
# 2.设置级别
logger.setLevel(logging.DEBUG) # 设置最低级别,小于它的级别不会输出
# 3.定义handler
# 3.1 控制台输出
sh = logging.StreamHandler()
sh.setLevel(logging.ERROR) # error 情况下,就会在控制台输出
# 3.2 写入log文件
fh = logging.FileHandler('test_file')
fh.setLevel(logging.DEBUG) # debug 级别以上我就写入log文件里
# 4.定义日志格式,格式化
formatter = logging.Formatter(
'时间: &(asctime)s,'
'日志级别: %(levelname)s,'
'日志消息: %(message)s'
)
# 把定义好的格式化添加到我们刚才定义的handler当中去
sh.setFormatter(formatter)
fh.setFormatter(formatter)
# 将我们的handler添加到logger里面去
logger.addHandler(sh)
logger.addHandler(fh)
if __name__ == '__main__':
# logger.debug('测试')
# logger.info('正常运行')
# logger.warn('警告')
# logger.error('报错')
# logger.critical('非常严重的错误')
def func(a):
try:
num = 20/a
logger.info(num) # 如果不报错,就正常运行
except Exception as e:
logger.error(e)
# 如果报错,就把报错信息扔进来,然后返回这个级别
func(0)
08 datetime与logging模块(进阶)的更多相关文章
- Python的 Datetime 、 Logging 模块
Datetime模块 datetime是python处理时间和日期的标准库 类名 date类 日期对象,常用的属性有 year . month . day time类 时间 ...
- logging模块进阶
python利用logging模块来记录日志主要涉及四个类 logger提供了应用程序可以直接使用的接口 handler将logger创建的日志提供的输出发送到指定目的地. filter起到过滤作用, ...
- day21——面向对象初识、结构、从类名研究类、从对象研究类、logging模块进阶版
day21 面向对象的初识 面向对象第一个优点: 对相似功能的函数,同一个业务下的函数进行归类,分类. 想要学习面向对象必须站在一个上帝的角度去分析考虑问题. 类: 具有相同属性和功能的一类事物. 对 ...
- logging模块进阶2
1.两种级别设置: 全局级别:生成logger对象后设置的级别 局部级别:生成handler对象设置的级别 我们都知道输出的级别不能低于设定的级别,那么全局级别和局部级别哪一个对输出产生影响? 经过多 ...
- 模块调用,datetime,time,logging,递归,双层装饰器, json,pickle迭代器和生成器
一.python模块(导入,内置,自定义,开源) 1.模块简介 模块是一个包含所有你定义的函数和变量的文件,其后缀名是.py.模块可以被别的程序引入,以使用该模块中的函数等功能.这也是使用python ...
- python模块概况,json/pickle,time/datetime,logging
参考: http://www.cnblogs.com/wupeiqi/articles/5501365.html http://www.cnblogs.com/alex3714/articles/51 ...
- Python自动化运维之9、模块之sys、os、hashlib、random、time&datetime、logging、subprocess
python模块 用一砣代码实现了某个功能的代码集合. 类似于函数式编程和面向过程编程,函数式编程则完成一个功能,其他代码用来调用即可,提供了代码的重用性和代码间的耦合.而对于一个复杂的功能来,可能需 ...
- 潭州课堂25班:Ph201805201 python 模块 datetime,logging 第七课 (课堂笔记)
datetime 模块 # -*- coding: utf-8 -*-# 斌彬电脑# @Time : 2018/7/9 0009 20:42import datetime d = datetime.d ...
- Python进阶(十一)----包,logging模块
Python进阶(十一)----包,logging模块 一丶包的使用 什么是包: 包是通过使用 .模块名的方式组织python模块名称空间的方式. 通俗来说,含有一个__init__.py文件的文 ...
随机推荐
- requireJS基本配置相关
requireJS: (1)实现js文件的异步加载,避免页面失去响应: (2)管理模块之间的依赖性,便于代码的编写和维护. 加载: <script src="js/require.js ...
- java:网络通讯
网络标准模型:开放式系统模型OSI https://www.cnblogs.com/lydit/articles/4499928.html 理解Scoket通讯:https://www.cnblogs ...
- PHP腾讯与百度坐标转换
function coordinate_switch($a,$b){//百度转腾讯坐标转换 $a = Latitude , $b = Longitude $x = (double)$b - 0.006 ...
- 什么是SWP文件?能否删除swp文件?
SWP意思就是交换文件..SWP是各种操作系统(Windows或Linux)使用的交换文件的文件扩展名. 可以安全地清理SWP文件以释放磁盘空间. 要清理SWP文件,请按照以下步骤操作: 运行WinU ...
- 技术blog
看到好多人都写技术blog,发现自己工作了快两年居然都没有写过blog,很是惭愧,遂从今天开始不定期更新技术体验,主要是为了记下自己学习摸索技术过程中的经验以及问题解决方案.
- python接口测试-项目实践(二)获取接口响应,取值(re、json)
一 分别请求3个接口,获取响应. 第三方接口返回有两种:1 纯字符串 2 带bom头的json字串 import requests api1 = 'url1' response1 = request ...
- python接口测试-项目实践(一) 测试需求与测试思路
测试需求: 第三方系统提供了3个接口,需要测试前端显示的字符串里的对应数据与接口数据是否一致. 测试分层: 开发人员的设计:每周从接口取一次数据,拼接完成后保存到数据库.再从数据库取数提供接口给前端开 ...
- IOS PushMeBaby(是一款用来测试ANPs的开源Mac项目)
● PushMeBaby是一款用来测试ANPs的开源Mac项目 ● 它充当了服务器的作用,用法非常简单 ● 它负责将内容提交给苹果的APNs服务器,苹果的APNs服务器再将内容推送给用户 的设备 ● ...
- 【[SDOI2008]洞穴勘测】
题目 由于始终保证连通性于是我们可以用\(LCT\)来维护这个森林 三个操作分别是\(link,cut,findroot\) 代码 #include<iostream> #include& ...
- 2018.11.10 Mac设置Eclipse的 .m2文件夹是否可见操作&&Mac系统显示当前文件夹的路径设置
第一行就是设置为可见的记得要重启Finder不然是没有效果的 第二行就是设置为不可见的 打开"终端"(应用程序->实用工具),输入以下两条命令: defaults write ...