1. 时间模块time、datetime

在python中,表示时间有三种方式:
时间戳

格式化的时间字符串(Format String): '2022-03-01'

时间元组(struct_time)

1.1 time模块

1.1.1 时间戳(time)

(1)生成时间戳

时间戳是指格林威治时间1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起至现在的总秒数。

import time  # 导入time模块

a = time.time()  # 生成时间戳,时间戳是浮点数类型
print(a, type(a)) # 1722591376.9927173 <class 'float'>

(2)时间戳转换为时间元组(UTC时间)     国际时间

将时间戳转换为UTC时间,与英国伦敦当地时间一致

import time

b = time.time()  # 生成时间戳
c = time.gmtime(b) # 时间戳转换为时间元组类型
print(c, type(c))
# time.struct_time(tm_year=2024, tm_mon=8, tm_mday=2, tm_hour=9, tm_min=43, tm_sec=59, tm_wday=4, tm_yday=215, tm_isdst=0) <class 'time.struct_time'>

(3)时间戳转换为时间元组(当地时间)

UTC时间+8小时=北京时间

import time

a = time.time()
b = time.localtime(a)
print(b)
# time.struct_time(tm_year=2024, tm_mon=8, tm_mday=2, tm_hour=17, tm_min=51, tm_sec=9, tm_wday=4, tm_yday=215, tm_isdst=0)

1.1.2 字符串格式化时间(strftime)

符号    含义              值
%y 两位数的年份表示 (00-99)
%Y 四位数的年份表示 (000-9999)
%m 月份 (01-12)
%d 月内中的一天   (0-31)
%H 24小时制小时数 (0-23)
%I 12小时制小时数 (01-12)
%M 分钟数 (00=59)
%S 秒 (00-59)
%a 本地简化星期名称
%A 本地完整星期名称
%b 本地简化的月份名称
%B 本地完整的月份名称
%c 本地相应的日期表示和时间表示
%j 年内的一天 (001-366)
%p 本地A.M.或P.M.的等价符
%U 一年中的星期数 (00-53)星期天为星期的开始
%w 星期 (0-6),星期天为星期的开始
%W 一年中的星期数 (00-53)星期一为星期的开始
%x 本地相应的日期表示
%X 本地相应的时间表示
%Z 当前时区的名称
%% %号本身
import time

# 时间元组放或不放都行
a = time.strftime('%Y-%m-%d %H:%M:%S')
print(a) # 2024-08-02 18:09:09
b = time.strftime('%Y-%m-%d %H:%M:%S', time.gmtime())
print(b) # 2024-08-02 10:09:09
c = time.strftime('%Y-%m-%d %H:%M:%S', time.localtime())
print(c) # 2024-08-02 18:09:09 d = time.strftime('%c')
print(d) # Fri Aug 2 18:09:09 2024

1.1.3 时间元组(struct_time)

(1)time.localtime   时间戳--->时间元组

import time

print(time.localtime())
# time.struct_time(tm_year=2024, tm_mon=8, tm_mday=2, tm_hour=18, tm_min=28, tm_sec=19, tm_wday=4, tm_yday=215, tm_isdst=0)

(2)time.mktime     时间元组--->时间戳

print(time.mktime(time.localtime()))  # 1722594776.0

(3)time.strftime     时间元组--->时间字符串

时间元组参数若不写,则使用当前时间

import time

print(time.strftime("%Y-%m-%d ", time.localtime()))
# 2024-08-02
print(time.strftime("%H:%M:%S ", time.localtime()))
# 18:50:35

(4)time.strptime 时间字符串--->时间元组

import time

print(time.strptime('2022-02-28 09:22:05', '%Y-%m-%d %H:%M:%S'))
# time.struct_time(tm_year=2022, tm_mon=2, tm_mday=28, tm_hour=9, tm_min=22, tm_sec=5, tm_wday=0, tm_yday=59, tm_isdst=-1)

(5)time.asctime    时间元组--->标准的时间格式

import time

print(time.asctime(time.localtime()))  # Fri Aug  2 19:05:20 2024
print(time.asctime()) # Fri Aug 2 19:05:20 2024

(6)time.ctime         时间戳--->标准的时间格式

import time

print(time.ctime(time.time()))  # Fri Aug  2 19:08:23 2024
print(time.ctime()) # Fri Aug 2 19:08:23 2024

1.1.4 小结

时间戳是计算机处理时间的方法

时间字符串是人类能够看懂的字符串

时间元组是两者的中间值,用来互相转换

1.2 datetime模块

(1)自定义日期并格式化输出

import datetime

a = datetime.date(2023, 11, 20)
print(a) # 2023-11-20

(2)获取当地时间

年月日

import datetime

print(datetime.date.today())  # 2024-08-02

年月日时分秒

import datetime

a = datetime.datetime.today()
print(a) # 2024-08-02 19:43:42.946123 # 以以上时间a为基础,可以得到更加具体的数据
print(a.year) # 2024
print(a.month) # 8
print(a.day) # 2
print(a.hour) # 19
print(a.minute) # 46
print(a.second) # 30
print(a.weekday) # 星期(weekday星期是0-6) 0表示周一
print(a.isoweekday) # 获取星期(weekday星期是1-7) 1表示周一

(3)timedelta  时间日期的增减对象

打印时间增减

import datetime

# 生成一个时间数据,可以对日期进行加减
ahead_day = datetime.timedelta(days=2)
print(ahead_day) # 2 days, 0:00:00 delay_day = datetime.timedelta(days=3)
print(delay_day) # 3 days, 0:00:00

对日期进行增减

import datetime

# 打印当前时间提前2天的具体时间
ahead_day = datetime.timedelta(days=2)
print(datetime.datetime.today() - ahead_day) # 2024-07-31 19:57:35.348771 # 打印当前时间往后3天的具体时间
delay_day = datetime.timedelta(days=3)
print(datetime.datetime.today() + delay_day) # 2024-08-05 19:59:09.937551

日期对象与timedelta之间的关系:

  日期对象 = 日期对象 + / - timedelta对象
     timedelta对象 = 日期对象 + / - 日期对象

2. 随机模块random

import random

# 1.随机生成0~1之间的小数 random
a = random.random()
print(a) # 0.46371291740686915 # 2.生成指定区间的小数 uniform
b = random.uniform(1, 2)
print(b) # 1.90434431469814 # 3.随机区间整数,两侧都可以取到 randint
c = random.randint(11, 13)
print(c) # 13 # 4.随机区间整数,要考虑起始值和步长 randrange
d = random.randrange(1, 10, 2)
print(d) # 1,3,5,7,9中取一个数 # 5.随机返回列表的一个元素 choice
e = ['messi', 'ronaldo', 'neymar', 'kylian']
print(random.choice(e)) # messi # 6.随机返回列表指定个数元素 sample
f = ['messi', 'ronaldo', 'neymar', 'kylian', 'haaland']
print(random.sample(f, 2))
# ['neymar', 'haaland'] # 7.打乱列表顺序,作用在原列表上 shuffle
g = [1, 2, 3, 4, 5, 6, 7, 8, 9]
random.shuffle(g)
print(g) # [1, 6, 8, 4, 5, 7, 3, 2, 9]

random模块的应用场景

# chr方法:根据ASCII码表的顺序,传入数字以展示对应的字符
import random print(chr(65)) # A
print(chr(90)) # Z
print(chr(97)) # a
print(chr(122)) # z # 生成一个6位数的随机验证码
def identify_code(n):
code = '' # 初始为空,循环一次字符串个数加一个
for i in range(n): # 定义循环的次数
upper_case = chr(random.randint(65, 90))
lower_case = chr(random.randint(97, 122))
num = str(random.randint(0, 9))
code += random.choice([upper_case, lower_case, num]) # 每次循环在大小写、数字中随机取一个
return code print(identify_code(6)) # j9025B

3. 摘要算法hashlib模块

3.1 概念

摘要算法又称为哈希算法、散列算法

通过一个函数将任意长度的数据转换成一个固定长度的字符串,16进制32位长度

摘要算法就是通过摘要函数f()对任意长度的数据data计算出固定长度的摘要digest,目的是为了发现原始数据是否被修改过。摘要算法之所以能指出数据是否被修改过,就是因为摘要函数是一个单向函数。
计算f(data)很容易,但通过digest反推data却非常困难。而且,对原始数据做一个bit的修改,都会导致计算出的摘要完全不同。

python的hashlib提供了常见的摘要算法:MD5、SHA1

3.2  md5算法

import hashlib

def encrypt(a):
tool = hashlib.md5() # 1.生成一个md5对象
a = a.encode() # 2.将传入的原始数据转成二进制
tool.update(a) # 3.对原始数据的二进制格式进行摘要加密
print(tool.hexdigest()) # 4.获取加密后的16进制字符串
print(tool.digest()) # 或者获取加密后的2进制字符串 encrypt('111111')

3.3 摘要算法升级之加盐

对原始数据加一个字符串,让原始数据和字符串一起加密,俗称“加盐”

def encrypt(data, salt):
tool = hashlib.md5() # 1.生成一个md5对象
final_data = data + salt # 2.对原始数据进行加盐
final_data = final_data.encode() # 3.加盐后的数据转成二进制
tool.update(final_data) # 4.加盐二进制进行摘要加密
print(tool.hexdigest()) # 5.获取加密后的16进制字符串
print(tool.digest()) # 或者获取2进制字符串 encrypt('111111', '111')
# bbb8aae57c104cda40c93843ad5e6db8
# b'\xbb\xb8\xaa\xe5|\x10L\xda@\xc98C\xad^m\xb8'

另一种写法

def encrypt(data, salt):
final_data = data + salt
final_data = final_data.encode()
encrypt_data = hashlib.md5(final_data)
print(encrypt_data.hexdigest())
print(encrypt_data.digest()) encrypt('111111', '111')
# bbb8aae57c104cda40c93843ad5e6db8
# b'\xbb\xb8\xaa\xe5|\x10L\xda@\xc98C\xad^m\xb8'

3.4 摘要算法的含义

摘要算法不是加密算法

加密算法的含义是:可以对原数据进行加密,并且可以对加密后的数据进行解密

摘要算法的含义是:单向加密,没有办法解密

4. 日志模块logging

模板

import logging
import logging.config # 定义日志输出格式 开始
standard_format = '[%(asctime)s][%(threadName)s:%(thread)d][task_id:%(name)s][%(filename)s:%(lineno)d]' \
'[%(levelname)s][%(message)s]' # 其中name为getlogger指定的名字
simple_format = '[%(levelname)s][%(asctime)s][%(filename)s:%(lineno)d]%(message)s'
# 定义日志输出格式 结束 # 自定义文件路径
logfile_path = 'rizhi.log' # log配置字典
LOGGING_DIC = {
'version': 1,
'disable_existing_loggers': False,
'formatters': {
'standard': {
'format': standard_format
},
'simple': {
'format': simple_format
},
},
'filters': {}, # 过滤日志
'handlers': {
# 打印到终端的日志
'console': {
'level': 'DEBUG', # NOTSET < DEBUG < INFO < WARNING < ERROR < CRITICAL
'class': 'logging.StreamHandler', # 打印到屏幕
'formatter': 'simple'
},
# 打印到文件的日志,收集info及以上的日志
'default': {
'level': 'DEBUG',
'class': 'logging.handlers.RotatingFileHandler', # 保存到文件
'formatter': 'standard',
'filename': logfile_path, # 日志文件
'maxBytes': 1024 * 1024 * 5, # 日志大小 5M
'backupCount': 5, # 保留最近5份
'encoding': 'utf-8', # 日志文件的编码,再也不用担心中文log乱码了
},
},
'loggers': {
# logging.getLogger(__name__)拿到的logger配置
# 当键为空不存在的情况下 (key设为空字符串)默认都会使用该k:v配置
'': {
'handlers': ['default', 'console'], # 这里把上面定义的两个handler都加上,即log数据既写入文件又打印到屏幕
'level': 'DEBUG',
'propagate': True,
# 向上(更高level的logger)传递,如果上一个键值对的值是debug,那么可以向上打印warning的信息
# 如果上有一个键值对的值是WARNING,那么不能向下打印debug的信息
}, # '注册记录': {
# 'handlers': ['console'], # 这里把上面定义的两个handler都加上,即log数据既写入文件又打印到屏幕
# 'level': 'WARNING',
# 'propagate': True, # 向上(更高level的logger)传递
# }, # 当键不存在的情况下 (key设为空字符串)默认都会使用该k:v配置
},
}
# 使用日志字典配置
# logging.config.dictConfig(LOGGING_DIC) # 自动加载字典中的配置
# logger1 = logging.getLogger('转账记录')
# logger2 = logging.getLogger('注册记录')
# logger1.debug('阿根廷足球巨星梅西')
# logger2.warning('法国足球巨星基利安姆巴佩') # logging.config.dictConfig(LOGGING_DIC) # 自动加载字典中的配置
# logger1 = logging.getLogger('withdraw record')
# '''loggers配置中使用空字符串作为字典的键 兼容性最好!!!'''
# logger1.debug('messi ronaldo neymar') logging.config.dictConfig(LOGGING_DIC)
a = logging.getLogger('注册信息')
a.debug('ronaldo注册')
# 定义产生日志的函数
def get_logger(name='', ):
'''
:param name: 日志等级
:return:
'''
# 初始化日志处理器 - 使用配置字典初始化日志处理器(将自定义配置加载到日志处理器中)
logging.config.dictConfig(LOGGING_DIC)
# 实例化日志处理器对象 - 并赋予日志处理器等级
logger = logging.getLogger(name)
# 返回日志生成对象
return logger

16 模块time、datetime、random、hashlib、logging的更多相关文章

  1. Python常用模块(time, datetime, random, os, sys, hashlib)

    time模块 在Python中,通常有这几种方式来表示时间: 时间戳(timestamp) :         通常来说,时间戳表示的是从1970年1月1日00:00:00开始按秒计算的偏移量.我们运 ...

  2. Python常用模块time & datetime &random 模块

    时间模块前言 在Python中,与时间处理有关的模块就包括:time,datetime 一.在Python中,通常有这几种方式来表示时间: 时间戳 格式化的时间字符串 元组(struct_time)共 ...

  3. python---基础知识回顾(四)(模块sys,os,random,hashlib,re,序列化json和pickle,xml,shutil,configparser,logging,datetime和time,其他)

    前提:dir,__all__,help,__doc__,__file__ dir:可以用来查看模块中的所有特性(函数,类,变量等) >>> import copy >>& ...

  4. python模块(shelve,xml,configparser,hashlib,logging)

    1.1shelve模块 shelve 模块比pickle模块简单,只有一个open函数,返回类似字典对象,可读可写:key必须为字符串, 而值可以是python所支持的数据类型. shelve模块主要 ...

  5. python开发模块基础:异常处理&hashlib&logging&configparser

    一,异常处理 # 异常处理代码 try: f = open('file', 'w') except ValueError: print('请输入一个数字') except Exception as e ...

  6. time,datetime,random,os,sys,hashlib,logging,configparser,re模块

    #-----time模块----- print(help(time)) #打印time帮助文档 print(time.time()) #打印时间戳 1569824501.6265268 time.sl ...

  7. (九)random、os、time、datetime、hashlib、pymysql、excel、sys、string相关模块

    1.random模块 1 import random,string 2 print(string.printable) #代表所有的 数字+字母+特殊字符 3 4 print(random.randi ...

  8. 【python】-- 模块、os、sys、time/datetime、random、logging、re

    模块 模块,用一堆代码实现了某个功能的代码集合. 类似于函数式编程和面向过程编程,函数式编程则完成一个功能,其他代码用来调用即可,提供了代码的重用性和代码间的耦合.而对于一个复杂的功能来,可能需要多个 ...

  9. Python——常用模块(time/datetime, random, os, shutil, json/pickcle, collections, hashlib/hmac, contextlib)

    1.time/datetime 这两个模块是与时间相关的模块,Python中通常用三种方式表示时间: #时间戳(timestamp):表示的是从1970年1月1日00:00:00开始按秒计算的偏移量. ...

  10. 模块讲解---time模块,datetime模块,random模块,hashlib模块和hmac模块,typing模块,requests模块,re模块

    目录 1. 包 2. time模块   1. 优先掌握 2. 了解 3. datetime模块   1. 优先掌握 4. random模块   1. 优先掌握   2. 了解 5. hashlib模块 ...

随机推荐

  1. [ABC363G] Dynamic Scheduling 与 P4511 [CTSC2015] 日程管理

    思路: 对于插入操作,设插入 \(\{t,p\}\): 若当前 \(1 \sim t\) 有空位,那么就放进去. 否则,\(1 \sim t\) 是被塞满了的: 首先容易想到的是找到 \(1 \sim ...

  2. SEO初学者指南之什么是SEO

    前言 Hi,大家好,我是听风.欢迎来到SEO基础入门指南.在这个博客中主要教大家SEO的基础知识,以谷歌SEO为主,重点放在实操方面. 虽然是基础入门教程,但我希望朋友们不要对"初学者&qu ...

  3. Mysql查询几天前或几天后的日期

    查询 当天±天数 后的日期."-14"表示14天前的日期,"14"表示14天后的日期 NOW()精确到时分秒,CURDATE()只精确到天 #查询今天 1.se ...

  4. 新手入门深度学习:在不使用Google的情况下如何在国内获得免费的算力 —— 算力共享,驱动人工智能创新的新引擎

    分享链接地址: 算力获新生 | 算力共享,驱动人工智能创新的新引擎

  5. 如何计算两个正太分布的KL散度 —— 正太分布的KL散度 (Kullback-Leibler divergence) 计算

    参考: https://blog.csdn.net/int_main_Roland/article/details/124650909 给出实现代码: def get_kl(): mean0, log ...

  6. 强化学习中经典算法 —— reinforce算法 —— (进一步理解, 理论推导出的计算模型和实际应用中的计算模型的区别)

    在奖励折扣率为1的情况下,既没有折扣的情况下,reinforce算法理论上可以写为: 但是在有折扣的情况下,reinforce算法理论上可以写为: 以上均为理论模型. ================ ...

  7. 韩国网费比其他国家贵10倍?—— 因网费太高,直播平台 Twitch 宣布2024年2月退出韩国市场

    看新闻,说直播平台 Twitch因为韩国的网费太贵宣布退出韩国,这个新闻给我看纳闷了,从来么有听说过哪个视频或直播公司因为网费贵而关停,这个估计是这种原因关停的第一家吧,于是比较好奇. 相关: htt ...

  8. mujoco安装报错:mujoco_py/gl/eglplatform.h:99:10: fatal error: X11/Xlib.h: 没有那个文件或目录

    安装mujoco报错: mujoco_py/gl/eglplatform.h:99:10: fatal error: X11/Xlib.h: 没有那个文件或目录 修复方法: sudo apt inst ...

  9. 为python编译C++模块时一定要注意的事情—————不要在anaconda环境下使用cmake来编译C++扩展模块!!!

    平时搞python的人很多都会有安装C++扩展模块的需求,而往往这些C++模块都是使用CMAKE做编译配置的,但是如果你这时候shell环境是使用anaconda的话,那么cmake默认调用的GCC和 ...

  10. 再探GraphRAG:如何提升LLM总结能力?

    作者:王振亚 编者语: 自微软发布GraphRAG之后,相关解读文层出不穷,其中不乏优秀的内容.比如前段时间转载薛明同学的<微软GraphRAG框架源码解读>让大家快速对GraphRAG的 ...