python之路-day21-模块介绍1
一、今日内容大纲
1、关于模块
import
from xxx import xxx 绝对导入
2、Collections
1)Counter 计数器
2)栈:先进后出
队列:先进先出
deque : 双向队列
3)defaultdict 默认值字典
4)namedtuple 元祖命名。struct_time 结构化时间就是命名元祖
5)OredereDict 有序字典,按照我们存储的顺序保存
3、time 时间模块
1)获取系统时间 time.time() 时间戳
2)格式化时间 strftime() 时间格式: %Y-%m-%d %H:%M:%S or %Y-%m-%d
3) 结构化时间:time.gmetime() time.localtime()----东八区
4)把格式化时间转化为结构时间 strptime()
把结构时间转化为时间戳 mktime()
4、os和sys
os.sep 文件路径分隔符
sys.path python查找模块的路径
二、Collections 模块
1、Counter计数器
from collections import Counter s = " i am sylar, i have a dream,,," ss = Counter(s) # 计算⼀个字符串中每个字符出现的次数 print(ss) dic = {} for el in s: # 如果字典中包含有给定键,则返回该键对应的值,否则返回为该键设置的值 dic[el] = dic.setdefault(el,0) + 1 print(dic) ##结果: Counter({' ': 7, 'a': 5, ',': 4, 'i': 2, 'm': 2, 'r': 2, 'e': 2, 's': 1, 'y': 1, 'l': 1, 'h': 1, 'v': 1, 'd': 1}) {' ': 7, 'i': 2, 'a': 5, 'm': 2, 's': 1, 'y': 1, 'l': 1, 'r': 2, ',': 4, 'h': 1, 'v': 1, 'e': 2, 'd': 1}
2. deque 双向队列.
(重点)说双向队列之前我们需要了解两种数据结构. 1. 栈, 2. 队列
1. 栈: FILO. 先进后出 -> 砌墙的砖头, 老师傅做馒头
2. 队列: FIFO. 先进先出 -> 买火⻋票排队, 所有排队的场景
# 栈 (先进后出) # class Stack: # def __init__(self,size): # self.index = 0 # 栈顶指针 # self.lst = [] # self.size = size # # # 给栈添加元素 # def push(self,item): # if self.index == self.size: # #栈已经满了,不能再装东西了 # pass # self.lst.insert(self.index,item) # 对于空列表,需要用insert插入内容 # self.index += 1 # 栈顶指针向上移动 # # # 从栈中获取数据 # def pop_item(self): # if self.index == 0: # pass # self.index -= 1 # 顶指针向下移动 # item = self.lst.pop(self.index) # 获取元素删除 # return item # # s = Stack(5) # 队列 # import queue 先进先出 # # # q = queue.Queue() # 创建队列 # q.put("李嘉诚") # q.put("深圳吴彦祖") # q.put("周润发") # q.put("韩寒") # # print(q.get()) # print(q.get()) # print(q.get()) # print(q.get()) # # print(q.get()) # 如果队列中没有元素了,继续获取的话会发生阻塞 # print("done") # # 双向队列 # # from collections import deque # # q = deque() # 创建一个双向队列 # q.append("高圆圆") # q.append("江疏影") # q.appendleft("赵又廷") # q.appendleft("刘某某") # # print(q.pop()) # print(q.pop()) # print(q.popleft()) # print(q.popleft()) # print(q.pop())
3、namedtuple 命名元组
命名元组, 顾名思义. 给元组内的元素进⾏命名. 比如. 我们说(x, y) 这是⼀个元组. 同时. 我们还可以认为这是⼀个点坐标.
这时, 我们就可以使⽤namedtuple对元素进⾏命名
# from collections import namedtuple # point = namedtuple("Point", ["x","y","z"]) # p = point(1,23,22) # print(p.x) # print(p.y) # print(p.z) # print(p)
4、defaultdict: 可以给字典设置默认值. 当key不存在时. 直接获取默认值:
# from collections import defaultdict # # lst = [11,22,33,44,55,66,77,88] # # d = defaultdict(list) # # for el in lst: # if el < 66: # d["key1"].append(el) # else: # d["key2"].append(el) # print(d)
三、time模块
# time # import time # while 1: # s = time.strftime("%Y-%m-%d %H:%M:%S") # print(s) # time.sleep(1) # import time # # t = time.gmtime(971150400.0) # s = time.strftime("%Y-%m-%d %H:%M:%S",t) # print(s) # s = "2000-10-10 12:00:00" # t = time.strptime(s,"%Y-%m-%d %H:%M:%S") # print(time.mktime(t)) # s = "2020-10-01 12:18:12" # t = time.strptime(s, "%Y-%m-%d %H:%M:%S") # 转化成结构时间 # print(time.mktime(t)) # 转换成时间戳 # 时间显示中文 # import locale,time # # locale.setlocale(locale.LC_COLLATE,"chinese") # print(time.strftime("%Y年%m月%d日")) # # 计算时间差 # import time # old_time = time.mktime(time.strptime("2018-11-10 10:30:00","%Y-%m-%d %H:%M:%S")) # nowtime = time.mktime(time.strptime("2018-11-10 12:00:00","%Y-%m-%d %H:%M:%S")) # dif_time = nowtime - old_time # total_min = int(dif_time / 60) # hour = int(total_min / 60) # min = int(total_min % 60) # print("时间差为:%s小时%s分"%(hour,min))
四、random 模块
import random print(random.randint(1,3)) # 1-3随机取一个,前后都为闭区间 print(random.random()) # 0-1 之间的小数 print(random.uniform(3,10)) # 3-10 之间的随机小数 print(random.randrange(1,10,3)) # [1,10) 从奇数中获取随机数 lst = [1,2,3,4,5,6] random.shuffle(lst) # 打散 print(lst) #[6, 1, 5, 3, 2, 4] print(random.choice([1, '周杰伦', ["盖伦", "胡辣汤"]])) #取一个元素 print(random.sample([1, '23', [4, 5]], 2)) # 列表元素任意2个组合
五、os模块
import os 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.system("bash command") #运⾏shell命令,直接显示 os.popen("bash command").read() #运⾏shell命令,获取执⾏结果 os.getcwd() #获取当前⼯作⽬录,即当前python脚本⼯作的⽬录路径 os.chdir("dirname") #改变当前脚本⼯作⽬录;相当于shell下cd # 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.sep #输出操作系统特定的路径分隔符,win下为"\\",Linux下为"/" os.linesep #输出当前平台使⽤的⾏终⽌符,win下为"\r\n",Linux下为"\n" os.pathsep #输出⽤于分割⽂件路径的字符串 win下为;,Linux下为: os.name #输出字符串指示当前使⽤平台。win->'nt'; Linux->'posix' os.stat() #属性解读: stat #结构: st_mode: inode 保护模式 st_ino: inode 节点号。 st_dev: inode 驻留的设备。 st_nlink: inode 的链接数。 st_uid: 所有者的⽤户ID。 st_gid: 所有者的组ID。 st_size: 普通⽂件以字节为单位的⼤⼩;包含等待某些特殊⽂件的数据。 st_mtime: 最后⼀次修改的时间。 st_ctime: 由操作系统报告的"ctime"。在某些系统上(如Unix)是最新的元数据更改的时间,在 其它系统上(如Windows)是创建时间(详细信息参⻅平台的⽂档)
六、sys模块
所有和python解释器相关的都在sys模块. sys.argv 命令⾏参数List,第⼀个元素是程序本身路径 sys.exit(n) 退出程序,正常退出时exit(0),错误退出sys.exit(1) sys.version 获取Python解释程序的版本信息 sys.path 返回模块的搜索路径,初始化时使⽤PYTHONPATH环境变量的值 sys.platform 返回操作系统平台名称