一、复习
collections
增加了一些扩展数据类型 :namedtuple orderdict defaltdict
队列和栈
time 时间
三种格式 : 时间戳 结构化 字符串
random
随机数 打乱顺序
sys
和python解释器交互的:
path 导入模块的时候 从这个路径中获取
argv 以脚本的形式执行一个文件的时候,可以加一些参数
import sys
print(sys.argv) #['xx.py','alex','sb']
学习方法:
先把老师的代码敲一遍,并把代码逐一注释
再开一个新文件,根据注释,还原代码
昨日作业讲解:
y-m-d h:M:S 比如2017-07-08 10:23:41 从当前时间开始 比起y-m-d h:M:S过去了多少年 多少月 多少天 多少小时,多少分,多少秒
步骤分解
当前的时间 时间戳
过去的时间 转成时间戳
时间戳相减
相减之后的结果转成结构化时间
结构化时间 - 1970.1.1 0:0:0 #英国时间
先来解释一下结构化时间,有2种方式,分别是
import time
struct_time = time.localtime(0)
ret = time.strftime('%Y-%m-%d %H:%M:%S',struct_time)
print(ret) # 中国结构化时间
struct_time = time.gmtime(0)
ret = time.strftime('%Y-%m-%d %H:%M:%S',struct_time)
print(ret) # 英国结构化时间
执行输出:
1970-01-01 08:00:00
1970-01-01 00:00:00
那么为什么要用英国时间呢?
因为英国时间的时分秒都是0,没有数字比0更小了。
但如果用中国时间,那么比8小的数字,就会出现负数,比如7:30
所以说,用英国时间,是最准确的。由于时分秒都是0,所以不需要相减
import time
def cal_time(fmt_time,fmt):
now = time.time()
time_before = time.mktime(time.strptime(fmt_time,fmt))
sub_time = now - time_before
struct_time = time.gmtime(sub_time)
return '过去了%d年%d月%d天%d小时%d分钟%d秒' % \
(struct_time.tm_year - 1970, struct_time.tm_mon - 1,
struct_time.tm_mday - 1, struct_time.tm_hour,
struct_time.tm_min, struct_time.tm_sec)
ret = cal_time('2018-4-23 10:30:20','%Y-%m-%d %H:%M:%S')
print(ret)
执行输出:
过去了0年0月2天4小时20分钟51秒
要求 生成随机验证码
基础需求: 6位数字验证码 数字可以重复
进阶需求: 字母+数字 4位验证码 数字字母都可以重复
这是一道面试题
完成第一个基础需求
import random
def id_code(num):
ret = '' # 定义空字符串
for i in range(num):
n = random.randint(0,9) # 数字由0~9组成
ret += str(n) # 将数字转换为字符串,并拼接
return ret
print(id_code(6))
执行输出:
803296
完成进阶需求
有一个难点,如果获取所有的大小写字母,全手写一遍?太Low了
这个时候,就需要用到ascii码。
import random
def id_code(num): # num 大写字母 小写字母在每一位被取到的概率相同
ret = ''
for i in range(num):
number = str(random.randint(0,9)) # 所有数字
alph_num = random.randint(97,122) # a97 z122 +25 所有小写字母
alph_num2 = random.randint(65,90) # A65 Z97 +25 所有大写字母
alph = chr(alph_num) # 大写
alph2 = chr(alph_num2) # 小写
choice = random.choice([number,alph,alph2]) # 数字,大写,小写。每种是1/3的几率
ret += choice # 组合字符串
return ret
print(id_code(6)) # 取6位
执行输出:
01J98C
额外一个需求,字母和数字,取50%的概率
import random
def id_code(num): # num 大写字母 小写字母在每一位被取到的概率相同
ret = ''
for i in range(num):
number = str(random.randint(0,9)) # 所有数字
alph_num = random.randint(97,122) # a97 z122 +25 所有小写字母
alph_num2 = random.randint(65,90) # A65 Z97 +25 所有大写字母
alph = chr(alph_num) # 大写
alph2 = chr(alph_num2) # 小写
choice = random.choice([alph, alph2]) # 字母大小写,取50%的概率
choice = random.choice([number,choice]) # 数字和字母,取50%的概率
ret += choice # 组合字符串
return ret
print(id_code(6)) # 取6位
执行输出:
Q4I17t
二、os模块
os模块是与操作系统交互的一个接口
当前执行的这个python文件目录相关的工作路径
os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径
os.chdir("dirname") 改变当前脚本工作目录;相当于shell下cd
os.curdir 返回当前目录: ('.')
os.pardir 获取当前目录的父目录字符串名:('..')
和文件夹相关的
os.makedirs('dirname1/dirname2') 可生成多层递归目录
os.removedirs('dirname1') 若目录为空,则删除,并递归到上一级目录,如若也为空,则删除,依此类推
os.mkdir('dirname') 生成单级目录;相当于shell中mkdir dirname
os.rmdir('dirname') 删除单级空目录,若目录不为空则无法删除,报错;相当于shell中rmdir dirname
os.listdir('dirname') 列出指定目录下的所有文件和子目录,包括隐藏文件,并以列表方式打印
和文件相关的
os.remove() 删除一个文件
os.rename("oldname","newname") 重命名文件/目录
os.stat('path/filename') 获取文件/目录信息
和操作系统差异相关的
os.sep 输出操作系统特定的路径分隔符,win下为"\\",Linux下为"/" os.linesep 输出当前平台使用的行终止符,win下为"\t\n",Linux下为"\n" os.pathsep 输出用于分割文件路径的字符串 win下为;,Linux下为: os.name 输出字符串指示当前使用平台。win->'nt'; Linux->'posix'
和执行系统命名相关的
os.system("bash command") 运行shell命令,直接显示
os.popen("bash command).read() 运行shell命令,获取执行结果
和环境变量相关的
os.environ 获取系统环境变量
和操作系统路径相关的os.path
os.path.abspath(path) 返回path规范化的绝对路径
os.path.split(path) 将path分割成目录和文件名二元组返回
os.path.dirname(path) 返回path的目录。其实就是os.path.split(path)的第一个元素
os.path.basename(path) 返回path最后的文件名。如果path以/或\结尾,那么就会返回空值。
即os.path.split(path)的第二个元素
os.path.exists(path) 如果path存在,返回True;如果path不存在,返回False
os.path.isabs(path) 如果path是绝对路径,返回True
os.path.isfile(path) 如果path是一个存在的文件,返回True。否则返回False
os.path.isdir(path) 如果path是一个存在的目录,则返回True。否则返回False
os.path.join(path1[, path2[, ...]]) 将多个路径组合后返回,第一个绝对路径之前的参数将被忽略
os.path.getatime(path) 返回path所指向的文件或者目录的最后访问时间
os.path.getmtime(path) 返回path所指向的文件或者目录的最后修改时间
os.path.getsize(path) 返回path的大小
注意:os.stat('path/filename') 获取文件/目录信息 的结构说明
stat 结构: st_mode: inode 保护模式 st_ino: inode 节点号。 st_dev: inode 驻留的设备。 st_nlink: inode 的链接数。 st_uid: 所有者的用户ID。 st_gid: 所有者的组ID。 st_size: 普通文件以字节为单位的大小;包含等待某些特殊文件的数据。 st_atime: 上次访问的时间。 st_mtime: 最后一次修改的时间。 st_ctime: 由操作系统报告的"ctime"。在某些系统上(如Unix)是最新的元数据更改的时间,在其它系统上(如Windows)是创建时间(详细信息参见平台的文档)。