文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

collections, time, o

2023-01-31 00:52

关注

1,collections模块

  • 统计字符串总字母的个数
    1 s = 'adskknawefkiewuhfbajfdcLSANlff'
    2 dic = {}
    3 for c in s:
    4     dic[c] = dic.get(c,0) + 1
    5 print(dic)
    6 
    7 from collections import Counter
    8 c = Counter(s)
    9 print(c)
  • 栈和队列
    Python中是能直接导入队列的模块
    队列:先进先出 first in first out (FIFO)
     1 import queue
     2 #创建队列
     3 q = queue.Queue()
     4 #放元素
     5 q.put("a")
     6 q.put("b")
     7 q.put("c")
     8 
     9 #拉元素
    10 print(q.get())
    11 print(q.get())
    12 print(q.get())
    13 #如果队列里面没有元素了,就阻塞,等待下一个元素的进入
    14 print(q.get())
    栈: 先进后出 first in last out
    1,入栈
    2,出栈
    属性:1,列表(容器)2,大小(size)3,栈顶指针(下一个装元素的位置)

     1 #栈
     2 #定义一个栈满了不能加数据的异常
     3 import traceback
     4 class FullError(Exception):
     5     pass
     6 #定义一个栈空了不能去数据的异常
     7 class EmptyError(Exception):
     8     pass
     9 class Zhan(object):
    10     def __init__(self,size):
    11         self.size = size
    12         self.index = 0
    13         self.lst = []
    14 
    15     def push(self,el):
    16         if self.index < self.size:
    17             self.lst.insert(self.index,el)
    18             self.index += 1
    19         else:
    20             raise FullError("栈满了")
    21 
    22     def pop(self):
    23         if self.index > 0:
    24             self.index -= 1
    25             self.lst.pop(self.index)
    26         else:
    27             raise EmptyError("栈空了")
    28 
    29 z = Zhan(5)
    30 try:
    31     z.push(1)
    32     z.push(2)
    33     z.push(3)
    34     z.push(4)
    35     z.push(5)
    36     #z.push(6)
    37 except FullError as e:
    38     print(e)
    39     val = traceback.format_exc()
    40     print(val)
    41 print(z.lst)
    42 
    43 
    44 try:
    45     z.pop()
    46     z.pop()
    47     z.pop()
    48     z.pop()
    49     z.pop()
    50     z.pop()
    51 except EmptyError as e:
    52     print(e)



  • 双向队列

     1 from collections import deque
     2 #创建一个双向队列
     3 b = deque()
     4 
     5 #向对列中加入元素
     6 b.append("a")#默认向右加入
     7 b.append("b")#默认向右加入
     8 b.append("c")#默认向右加入
     9 #B : a,b,c
    10 b.appendleft("d")#向左加入
    11 #B :  d,a,b,c
    12 
    13 #向对列中拿出元素
    14 b.pop()#默认向右删除
    15 b.pop()#默认向右删除
    16 #B : d,a
    17 b.popleft()#向左删除
    18 #B : a

2,time

  时间分三种,时间戳,结构化时间,格式化时间,三者之间通过结构化的时间能相互转化

 

 1 import time
 2 print(time.time()) #得到一个时间戳,给机器看的#1560225767.5565157
 3 #时间戳是以1970-01-01 00:00:00为原点
 4 
 5 #格式化时间,
 6 print(time.strftime("%Y-%m-%d %H:%M:%S"))#2019-06-11 12:02:47
 7 
 8 #结构化时间
 9 print(time.localtime())#time.struct_time(tm_year=2019, tm_mon=6, tm_mday=11, tm_hour=12, tm_min=11, tm_sec=51, tm_wday=1, tm_yday=162, tm_isdst=0)
10 
11 #时间戳转化结构化时间
12 h = 18888822233
13 st = time.localtime(h)
14 print(st)#time.struct_time(tm_year=2568, tm_mon=7, tm_mday=24, tm_hour=23, tm_min=3, tm_sec=53, tm_wday=6, tm_yday=206, tm_isdst=0)
15 #结构化时间转化成格式化时间
16 ft = time.strftime("%Y-%m-%d %H:%M:%S", st)
17 print(ft)#2568-07-24 23:03:53
18 
19 #格式化时间转化结构化时间
20 s = "2019-07-24 23:03:53"
21 ht = time.strptime(s,"%Y-%m-%d %H:%M:%S")
22 print(ht)#time.struct_time(tm_year=2019, tm_mon=7, tm_mday=24, tm_hour=23, tm_min=3, tm_sec=53, tm_wday=2, tm_yday=205, tm_isdst=-1)
23 #结构化时间转换时间戳
24 c = time.mktime(ht)
25 print(c)#1563980633.0

 

  时间格式

  

%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 当前时区的名称
%% %号本身
View Code

 

3,os模块

  os模块是与操作系统交互的一个接口,运行操作系统的命令

  

 1 os.makedirs('dirname1/dirname2')    可生成多层递归目录
 2 os.removedirs('dirname1')    若目录为空,则删除,并递归到上一级目录,如若也为空,则删除,依此类推
 3 os.mkdir('dirname')    生成单级目录;相当于shell中mkdir dirname
 4 os.rmdir('dirname')    删除单级空目录,若目录不为空则无法删除,报错;相当于shell中rmdir dirname
 5 os.listdir('dirname')    列出指定目录下的所有文件和子目录,包括隐藏文件,并以列表方式打印
 6 os.remove()  删除一个文件
 7 os.rename("oldname","newname")  重命名文件/目录
 8 os.stat('path/filename')  获取文件/目录信息
 9  
10 os.system("bash command")  运行shell命令,直接显示
11 os.popen("bash command).read()  运行shell命令,获取执行结果
12 os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径
13 os.chdir("dirname")  改变当前脚本工作目录;相当于shell下cd
14  
15  
16 os.path
17 os.path.abspath(path) 返回path规范化的绝对路径
18 os.path.split(path) 将path分割成目录和文件名二元组返回
19 os.path.dirname(path) 返回path的目录。其实就是os.path.split(path)的第一个元素
20 os.path.basename(path) 返回path最后的文件名。如何path以/或\结尾,那么就会返回空值。即os.path.split(path)的第二个元素
21 os.path.exists(path)  如果path存在,返回True;如果path不存在,返回False
22 os.path.isabs(path)  如果path是绝对路径,返回True
23 os.path.isfile(path)  如果path是一个存在的文件,返回True。否则返回False
24 os.path.isdir(path)  如果path是一个存在的目录,则返回True。否则返回False
25 os.path.join(path1[, path2[, ...]])  将多个路径组合后返回,第一个绝对路径之前的参数将被忽略
26 os.path.getatime(path)  返回path所指向的文件或者目录的最后访问时间
27 os.path.getmtime(path)  返回path所指向的文件或者目录的最后修改时间
28 os.path.getsize(path) 返回path的大小

 

 1 stat 结构:
 2  
 3 st_mode: inode 保护模式
 4 st_ino: inode 节点号。
 5 st_dev: inode 驻留的设备。
 6 st_nlink: inode 的链接数。
 7 st_uid: 所有者的用户ID。
 8 st_gid: 所有者的组ID。
 9 st_size: 普通文件以字节为单位的大小;包含等待某些特殊文件的数据。
10 st_atime: 上次访问的时间。
11 st_mtime: 最后一次修改的时间。
12 st_ctime: 由操作系统报告的"ctime"。<br>在某些系统上(如Unix)是最新的元数据更改的时间,在其它系统上(如Windows)是创建时间(详细信息参见平台的文档)。
13 
14 
15 os.sep    输出操作系统特定的路径分隔符,win下为"\\",Linux下为"/"
16 os.linesep    输出当前平台使用的行终止符,win下为"\r\n",Linux下为"\n"
17 os.pathsep    输出用于分割文件路径的字符串 win下为;,Linux下为:
18 os.name    输出字符串指示当前使用平台。win->'nt'; Linux->'posix'

 

4,sys模块

  

 1 sys.argv           命令行参数List,第一个元素是程序本身路径
 2 sys.exit(n)        退出程序,正常退出时exit(0),错误退出sys.exit(1)
 3 sys.version        获取Python解释程序的版本信息
 4 sys.path           返回模块的搜索路径,初始化时使用PYTHONPATH环境变量的值
 5 sys.platform       返回操作系统平台名称
 6   
 7 import sys
 8 try:
 9     sys.exit(1)
10 except SystemExit as e:
11     print(e)

 

5,random模块

random模块是用来产生随机数的

 1 print(random.random()) #  0-1小数  想办法完成[1,100]之间的随机整数
 2 print(random.uniform(1, 3)) # 1-3之间的小数
 3  
 4 print(random.randint(1, 36)) # [1,36]随机整数
 5 print(random.randrange(1, 5, 3)) # [1, 5) 步长是3
 6  
 7  
 8 print(random.choice(["马化腾", ["倚天屠龙记", "天龙八部", "射雕"], "张无忌", "周伯通", "刘伟"])) <br># 随机选一个
 9 print(random.sample(["刘伟", "大阳哥", "大猪蹄子", "胡辣汤"], 3))
10 print(random.sample(list(range(1,37)), 7))
11  
12  
13 lst = [1,2,3,4,5,5,6,7,8,9,]
14 random.shuffle(lst) # 随机打烂列表顺序
15 print(lst)

 

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯