首页 > 代码库 > 那些年被我坑过的Python——道阻且长(第五章实用模块讲解)

那些年被我坑过的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             pass11     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                                )
logging模块使用简述

 

sys和os模块

 

技术分享
 1 sys.argv           命令行参数List,第一个元素是程序本身路径 2 sys.exit(n)        退出程序,正常退出时exit(0) 3 sys.version        获取Python解释程序的版本信息 4 sys.maxsize        最大的Int值 5 sys.path           返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值 6 sys.platform       返回操作系统平台名称 7 sys.stdout.write(please:) 8 val = sys.stdin.readline()[:-1] 9 10 os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径11 os.chdir("dirname")  改变当前脚本工作目录;相当于shell下cd12 os.curdir  返回当前目录: (.)13 os.pardir  获取当前目录的父目录字符串名:(..)14 os.makedirs(dirname1/dirname2)    可生成多层递归目录15 os.removedirs(dirname1)    若目录为空,则删除,并递归到上一级目录,如若也为空,则删除,依此类推16 os.mkdir(dirname)    生成单级目录;相当于shell中mkdir dirname17 os.rmdir(dirname)    删除单级空目录,若目录不为空则无法删除,报错;相当于shell中rmdir dirname18 os.listdir(dirname)    列出指定目录下的所有文件和子目录,包括隐藏文件,并以列表方式打印19 os.remove()  删除一个文件20 os.rename("oldname","newname")  重命名文件/目录21 os.stat(path/filename)  获取文件/目录信息22 os.sep    输出操作系统特定的路径分隔符,win下为"\\",Linux下为"/"23 os.linesep    输出当前平台使用的行终止符,win下为"\t\n",Linux下为"\n"24 os.pathsep    输出用于分割文件路径的字符串25 os.name    输出字符串指示当前使用平台。win->nt; Linux->posix26 os.system("bash command")  运行shell命令,直接显示27 os.environ  获取系统环境变量28 os.path.abspath(path)  返回path规范化的绝对路径29 os.path.split(path)  将path分割成目录和文件名二元组返回30 os.path.dirname(path)  返回path的目录。其实就是os.path.split(path)的第一个元素31 os.path.basename(path)  返回path最后的文件名。如何path以/或\结尾,那么就会返回空值。即os.path.split(path)的第二个元素32 os.path.exists(path)  如果path存在,返回True;如果path不存在,返回False33 os.path.isabs(path)  如果path是绝对路径,返回True34 os.path.isfile(path)  如果path是一个存在的文件,返回True。否则返回False35 os.path.isdir(path)  如果path是一个存在的目录,则返回True。否则返回False36 os.path.join(path1[, path2[, ...]])  将多个路径组合后返回,第一个绝对路径之前的参数将被忽略37 os.path.getatime(path)  返回path所指向的文件或者目录的最后存取时间38 os.path.getmtime(path)  返回path所指向的文件或者目录的最后修改时间
sys和os

 

hmac模块

  还是比较简单的,不过,无论是加密的key还是加密的value都需要是bytes类型

   .new()需要传入key也就是加密的口令

   .update()是传入加密的明文

   .hexdigest()是以16进制的字符显示加密后的密码

account = input("请输入账号:")password = input("请输入密码:")encrypt = hmac.new(bytes(account.encode(encoding=‘utf-8‘)))encrypt.update(bytes(password.encode(encoding=‘utf-8‘)))encrypted_password = str(encrypt.hexdigest())print(encrypted_password)

 

那些年被我坑过的Python——道阻且长(第五章实用模块讲解)