一、collections   模块
1:nametuple  生成可以用名字访问内容的元祖
from collections import namedtuple
point=namedtuple('point',['x','y'])
p1=point(1,2)
p2=point(3,4)
print(p1.x) #
print(p1.y) #
print(p1,p2) #point(x=1, y=2) point(x=3, y=4)

2、deque  双端队列 头尾皆可以进出,实现高效的删除和添加,适用于队列和栈
先了解队列   queue  先进先出
import queue
q=queue.Queue()
q.put([1,2,3])
q.put(5)
q.put(6)
print(q) #<queue.Queue object at 0x017E3A90> deque(['1', '2', '3'])
print(q.get()) #[1, 2, 3]
print(q.get()) #
print(q.get()) #
print(q.qsize()) #打印剩余列表长度
再讲讲deque   双端队列
from collections import deque
l=deque(['','',''])
l.append('') #deque(['1', '2', '3', '4'])
l.appendleft('') #deque(['6', '1', '2', '3', '4'])
l.pop() #deque(['6', '1', '2', '3'])
l.popleft() #deque(['1', '2', '3'])
l.pop() #deque(['1', '2'])
print(l)
3、OrderedDict  有序字典  插入会按照你插入的顺序打印
from collections import OrderedDict
dic=OrderedDict([('a','b'),('g',3)])
print(dic) #OrderedDict([('a', 'b'), ('g', 3)]) 是有序
dic['c']=4
dic['d']=5
print()
print(dic) #OrderedDict([('a', 'b'), ('g', 3), ('c', 4), ('d', 5)])
4、defaultdict   当不改变value,默认字典的value是一个可调用的变量
有如下值集合 [11,22,33,44,55,66,77,88,99,90...],将所有大于 66 的值保存至字典的第一个key中,
将小于 66 的值保存至第二个key的值中。即: {'k1': 大于66 , 'k2': 小于66}
from collections import defaultdict
values = [11, 22, 33,44,55,66,77,88,99,90]
dic=defaultdict(list) # 默认字典的value是一个空列表
for i in values:
if i<66:
dic['k1'].append(i)
else:
dic['k2'].append(i)
print(dic) #defaultdict(<class 'list'>, {'k1': [11, 22, 33, 44, 55], 'k2': [66, 77, 88, 99, 90]})
使用dict时,如果引用的Key不存在,就会抛出KeyError。
如果希望key不存在时,返回一个默认值,就可以用defaultdict
from collections import defaultdict
dic=defaultdict(lambda:5)
dic['a']=2
print(dic['c']) #当没有key‘c'时,会把默认的value 5 给 c
5、Counter  计数
from collections import Counter
c=Counter('sdgnsfnbfgb')
print(c) #Counter({'n': 2, 'b': 2, 'g': 2, 's': 2, 'f': 2, 'd': 1})
print(c['b']) #
进阶解析
Counter类的创建
c=Counter() #建立一个空的Counter类
c=Counter('sdgnsfnbfgb') #从一个可iterable对象(list、tuple、dict、字符串等)创建
c=Counter(a=1,b=2) #从一组键值对创建
c=Counter({'a':1,'b'=2}) #从一个字典对象创建

二、time模块
结构化时间:truct time     (2017-1-10)
格式化时间:format time (%Y %m %d %a %)
时间戳:timestamp
导入时间模块 import tim
1、时间戳:
import time
print(time.time()) #1515578559.069024 是秒来计算显示的
2、结构化时间:
时间元组:localtime将一个时间戳转换为当前时区的struct_time
import time
t2=time.localtime()
print(t2)
print(t2.tm_year) #
#time.struct_time(tm_year=2018, tm_mon=1, tm_mday=10, tm_hour=18, tm_min=27, tm_sec=35,tm_wday=2, tm_yday=10, tm_isdst=0)
print(time.localtime(2000000000))
#time.struct_time(tm_year=2033, tm_mon=5, tm_mday=18, tm_hour=11, tm_min=33, tm_sec=20, tm_wday=2, tm_yday=138, tm_isdst=0)

3、格式化时间:

import time
t=time.strftime('%Y-%m-%d %a %H:%M:%S')
print(t) #2018-01-10 Wed 18:19:05
4、结构化时间  时间戳  格式化时间的互相转化 是通过结构化时间 作为桥梁实现的

structime--->formatime    strftime
import time
t1=time.localtime(200000000)
t2=time.strftime('%Y-%m-%d %a %H:%M:%S',t1)
print(t2) #1976-05-04 Tue 03:33:20
formatime--->structime     strptime
t1=time.strptime('2018-1-10','%Y-%m-%d')
print(t1)
#time.struct_time(tm_year=2018, tm_mon=1, tm_mday=10, tm_hour=0, tm_min=0, tm_sec=0, tm_wday=2, tm_yday=10, tm_isdst=-1)
timestamp---->structime    gmtime
t=time.time()
t1=time.gmtime(t)
print(t1) #time.struct_time(tm_year=2018, tm_mon=1, tm_mday=10, tm_hour=10, tm_min=58, tm_sec=24, tm_wday=2, tm_yday=10, tm_isdst=0)
structime---->timestamp    mktime
t1=time.localtime()
t2=time.mktime(t1)
print(t2) #1515582114.0
timestamp--->formatime
t=time.time()     #timestamp
t1=time.gmtime(t) #timestamp-->structime
t2=time.strftime('%Y-%m-%d %a %H:%M:%S',t1) #structime--->formatime
print(t2) #2018-01-10 Wed 11:17:25
formatime--->timestamp
t=time.strptime('2018-1-10',"%Y-%m-%d")   #formatime-->structime
t2=time.mktime(t) #structime--->timestamp
print(t2) #1515513600.0
asctime   固定转换为一种特定的格式:结构化时间 --> %a %b %d %H:%M:%S %Y串  格式化时间
不传参,返回当地时间
print(time.asctime())    #Wed Jan 10 19:22:45 2018
#传参
print(time.asctime(time.localtime(1500000000))) #Fri Jul 14 10:40:00 2017
ctime    timestamp-->%a %d %d %H:%M:%S %Y 格式化时间
print(time.ctime())    #Wed Jan 10 19:27:27 2018
print(time.ctime(1500000000)) #Fri Jul 14 10:40:00 2017
三、random模块,获取随机数
先导入模块: import random模块
1、随机小数  random  uniform
print(random.random())   #0.35517499752317194随机获取一个小数
print(random.uniform(1,3)) #2.0443241211504923随机获取一个1-4之间的小数
2,随机整数 randint  randrange
print(random.randint(1,5))   #随机获取一个1-5之间的整数
print(random.randrange(1,10,2)) #随机获取一个1-10之间的奇数
3、choice  随机选择一个返回  choice   里面要随机匹配的数字范围要用中括号[]括起来
print(random.choice([1,[2,3],5]))   #
4、smple随机选择多个返回,返回的个数为函数的第二个参数
print(random.sample([1,[2,3],5],2))    #[[2, 3], 5]
5、打乱列表顺序shuffle
l=[1,2,8,9,4,3,5,7,6,8]
random.shuffle(l)
print(l) #[5, 9, 3, 4, 2, 7, 8, 6, 1, 8]
 

 
												

python--常用模块:collections 、time、random的更多相关文章

  1. python常用模块collections os random sys

    Python 模块(Module),是一个 Python 文件,以 .py 结尾,包含了 Python 对象定义和Python语句. 模块让你能够有逻辑地组织你的 Python 代码段. 把相关的代码 ...

  2. day19:常用模块(collections,time,random,os,sys)

    1,正则复习,re.S,这个在用的最多,re.M多行模式,这个主要改变^和$的行为,每一行都是新串开头,每个回车都是结尾.re.L 在Windows和linux里面对一些特殊字符有不一样的识别,re. ...

  3. 20、Python常用模块sys、random、hashlib、logging

    一.sys运行时环境模块 sys模块负责程序与python解释器的交互,提供了一系列的函数和变量,用于操控python的运行时环境. 用法: sys.argv:命令行参数List,第一个元素是程序本身 ...

  4. python常用模块---collections、time、random、os、sys、序列号模块

    collections模块 在内置数据类型(dict.list.set.tuple)的基础上,collections模块还提供了几个额外的数据类型:Counter.deque.defaultdict. ...

  5. Python常用模块(time, datetime, random, os, sys, hashlib)

    time模块 在Python中,通常有这几种方式来表示时间: 时间戳(timestamp) :         通常来说,时间戳表示的是从1970年1月1日00:00:00开始按秒计算的偏移量.我们运 ...

  6. Python常用模块time & datetime &random 模块

    时间模块前言 在Python中,与时间处理有关的模块就包括:time,datetime 一.在Python中,通常有这几种方式来表示时间: 时间戳 格式化的时间字符串 元组(struct_time)共 ...

  7. Python常用模块--collections

    collections是Python中一个非常强大的容器数据模块. 1.创建升级版的元组--namedtupe Python的元组(1,2,3)具有不可变性,但是单独的元组在无法满足现有需求时,可以使 ...

  8. python常用模块——collections

    好久没学习了,简单了解下 Ⅰ.namedtuple 1.1 简单回顾一下tuple tuple是一个不可变的可迭代对象 ①可迭代 In [1]: test_tuple = (1,2,3,4,5) In ...

  9. Python常用模块——目录

    Python常用模块学习 Python模块和包 Python常用模块time & datetime &random 模块 Python常用模块os & sys & sh ...

  10. python常用模块(1):collections模块和re模块(正则表达式详解)

    从今天开始我们就要开始学习python的模块,今天先介绍两个常用模块collections和re模块.还有非常重要的正则表达式,今天学习的正则表达式需要记忆的东西非常多,希望大家可以认真记忆.按常理来 ...

随机推荐

  1. java中的三大特性

    java的三大特性是封装.继承.多态: 继承是OOD(面向对象设计)为了更好的建模,编程的时候是OOP(面向对象编程)提高代码的复用性.这里有个注意点:一个类只有一个直接的父类,但不是只有一个父类. ...

  2. 转 Jmeter如何把响应数据的结果保存到本地的一个文件

    当做性能压测时,可能会需要把响应数据的一些字段统计出来.这里简单介绍一下. 1.首先把接口调通,确定需要统计的字段,这里以统计ccmpSeq字段来做例子. 2.添加正则表达式提取器,用来提取响应结果中 ...

  3. Spring Cloud服务安全连接

    Spring Cloud可以增加HTTP Basic认证来增加服务连接的安全性. 1.加入security启动器 在maven配置文件中加入Spring Boot的security启动器. <d ...

  4. [已解决]报错:xlrd.compdoc.CompDocError: Workbook: size exceeds expected 17920 bytes; corrupt?

    报错代码如下: filePath='test.xls' data=pd.read_excel(filePath) print(data.head()) 报错内容如下: Traceback (most ...

  5. Error (10170): Verilog HDL syntax error at passwd.v(21) near text "if"; expecting an identifier ("if" is a reserved keyword ), or "endmodule", or a parallel statement

    你得加上时序啊笨蛋

  6. tomcat部署项目后,项目没有成功部署到tomcat里面,或者部署的是之前项目

    用svn下载java项目到本地,导入eclipse里面,然后部署到tomcat里,启动tomcat,一闪而过,在浏览器中打开,报404错(找不到页面),其实是项目没有成功部署到tomcat,可以打开t ...

  7. 无法启动此程序 ,因为计算机中丢失MSVCP120.dll

    1.文件丢失问题 无法启动此程序 ,因为计算机中丢失MSVCP120.dll 具体如下图所示: 等dll文件丢失,可以去下载 DirectX修复工具去修复即可 http://www.pc6.com/s ...

  8. shell 脚本文件类型.sh ,变量

    1. shell脚本编程的基本过程 (1)建立shell文件,以 .sh 结尾的文件 (2)赋予shell文件执行权限,chmod 0777 文件名 (3)执行shell文件, ./ 文件名 或者ba ...

  9. 2018-2019 ACM-ICPC, Asia Seoul Regional Contest K TV Show Game 2-sat

    题目传送门 题意: 有n个人,k盏灯,灯有红蓝两种颜色,每个人都猜了三种灯的颜色,问如何安排灯的颜色,使得每个人猜的灯至少有两个是对的. 思路: 很容易想到2-sat,但是显然枚举每个人猜对的情况是不 ...

  10. kubernetes报错

    错误信息:执行yaml文件后,服务在运行,但是提示命令找不到 原因:没有环境,相当于只有一个快捷方式 环境目录为/usr/local/bin 解决办法:将/etc/ansible/bin下的文件都拷贝 ...