那些年被我坑过的Python——道阻且长(第五章实用模块讲解)
random模块
我的随机验证吗程序:
首先保证了字母和数字出现的概率是50% VS 50%,其次是可以订制输出多少位
1 def Captcha(size): 2 Captcha_list = [] 3 for i in range(size): 4 rand_num = random.randint(1, 2) 5 if rand_num == 1: 6 Captcha_list.append(chr(random.randint(65, 90))) 7 elif rand_num == 2: 8 Captcha_list.append(str(random.randint(0, 9))) 9 else: 10 pass 11 return ''.join(Captcha_list)
time模块
时间日期常用的模块有time和datetime,datetime是对time的高级封装
时间的格式有三种,互相之间可以进行相互转化,分别是:
1、时间戳格式,是一串距1970-01-01至今的秒数time.time();
time.time()
2、时间结构体 time.localtime()
time.localtime()
3、格式化后的时间字符串,格式化表达式类似于秘钥对时间进行加密,加密后的效果为格式化的时间,同样也可使用表达式进行反解
# 日期字符串转成时间戳 string_2_struct = time.strptime("2016/05/22","%Y/%m/%d") print(string_2_struct) #将struct时间对象转成时间戳 struct_2_stamp = time.mktime(string_2_struct) print(struct_2_stamp) # 将utc时间戳转换成struct_time格式 print(time.gmtime(time.time()-86640)) #将utc struct_time格式转成指定的字符串格式 print(time.strftime("%Y-%m-%d %H:%M:%S",time.gmtime()))
shelve模块
一个很方便的序列化工具,以key value的形式持久化python对象
# 完全可以把shelve看成一个文件字典 with shelve.open(filename, flag='c') as sdb: sdb[key] = value
具体的使用其实和字典没什么两样,增改操作就是对shelv_obj[key] = value,删除操作使用del关键字即可
del shelve_obj[key]
logging模块
一些说明:
logging.basicConfig函数各参数:
filename: 指定日志文件名
filemode: 和file函数意义相同,指定日志文件的打开模式,'w'或'a'
format: 指定输出的格式和内容,format可以输出很多有用信息,如上例所示:
%(levelno)s: 打印日志级别的数值
%(levelname)s: 打印日志级别名称
%(pathname)s: 打印当前执行程序的路径,其实就是sys.argv[0]
%(filename)s: 打印当前执行程序名
%(funcName)s: 打印日志的当前函数
%(lineno)d: 打印日志的当前行号
%(asctime)s: 打印日志的时间
%(thread)d: 打印线程ID
%(threadName)s: 打印线程名称
%(process)d: 打印进程ID
%(message)s: 打印日志信息
datefmt: 指定时间格式,同time.strftime()
level: 设置日志级别,默认为logging.WARNING
stream: 指定将日志的输出流,可以指定输出到sys.stderr,sys.stdout或者文件,默认输出到sys.stderr,当stream和filename同时指定时,stream被忽略
1 ''' 2 log_handler = logging.basicConfig(level=logging.DEBUG, 3 format='%(asctime)s [%(levelname)s]: %(message)s', 4 datefmt='%Y%m%d %H:%M:%S', 5 filename=LOG_DIR, 6 filemode='w') 7 ''' 8 # 创建日志对象 9 logger = logging.getLogger('TEST-LOG') 10 11 # 设定日志的底线级别 12 logger.setLevel(logging.DEBUG) 13 14 # 创建日志的文件操作句柄 15 fh = logging.FileHandler(LOG_DIR,encoding='utf-8') 16 fh.setLevel(logging.DEBUG) 17 18 # 设定全局格式表达式 19 formatter = logging.Formatter('%(asctime)s [%(levelname)s]: %(message)s') 20 21 # 加载格式表达式 22 fh.setFormatter(formatter) 23 24 # 启用文件句柄记录日志,实现对日志文件的操作 25 logger.addHandler(fh) 26 27 28 # 记录相应级别的日志,如果低于全局日志底线级别的,则不会被记录 29 logger_obj.info("账号<%s> 进行了%s操作 金额变化:(%s) 金额%s利息%s 余额为%s" 30 % (srcaccount_data['id'], 31 type, 32 TRANSACTION_TYPE[type]["action"], 33 amount, 34 interest, 35 src_new_balance) 36 )