python中的各个模块
collection模块:python中的扩展数据模块
#namedtuple: 生成可以使用名字来访问元素内容的tuple
'''from collections import namedtuple
Point=namedtuple('point',['x','y']) #必须起名字 point
p=Point(1,2)
print(p.x) #表示坐标中的x点
print(p.y)
print(p) #point(x=1, y=2) 表示坐标'''
#deque 双端队列,快速的从另外一侧追加和推出对象 适用于队列和栈
#队列queue:先进先出 FIFO 堆栈:先进后出 list是线性存储
'''from collections import deque
q=deque([1,2])#创建一个队列,队列里面放一个列表
q.append('d')#从后面放数据
q.appendleft('e')#从前面放数据
q.insert(1,4)#插队
# q.pop()#从后面去数据
# q.popleft()#从前面取数据
print(q.pop())
print(q.popleft())'''
#OrderedDict:有序字典---》保持key的顺序
'''from collections import OrderedDict
d=dict([('a',1),('b',2),('c',3)])
print(d)#c此时无序
d1=OrderedDict([('a',1),('b',2),('c',3)])
print(d1)#OrderedDict([('a', 1), ('b', 2), ('c', 3)])此时有序'''
# counter:计数器,用来计数 无序的容器类型 #defaultdict:带有默认值得字典
'''from collections import Counter
c=Counter('vcbdjsihguirehgslkjfsdkfjiugh')
print(c)
#Counter({'j': 3, 's': 3, 'i': 3, 'h': 3, 'g': 3, 'd': 2, 'u': 2, 'k': 2, 'f': 2, 'v': 1, 'c': 1, 'b': 1, 'r': 1, 'e': 1, 'l': 1})
'''
#给集合排序 大与某个值的和小于某个值的存放在两个key下面
'''from collections import defaultdict
dic=[11, 22, 33,44,55,66,77,88,99,90]
d1=defaultdict(list)
for i in dic:
if i>66:
d1['k1'].append(i)
else:
d1['k2'].append(i)
print(d1) #defaultdict(<class 'list'>, {'k2': [11, 22, 33, 44, 55, 66], 'k1': [77, 88, 99, 90]})'''
#时间模块
#导入时间模块
#常用的方法
# 1.time.time() 获取当前时间
# 2.time.sleep(secs) 推迟的时间戳
#表示时间的三种方式
#时间戳:时间戳表示的是从1970年1月1日00:00:00开始按秒计算的偏移量。我们运行“type(time.time())”,返回的是float类型
# 元组(struct_time):
# 格式化的时间字符串Format String ‘1999-12-06’
'''import time
#时间戳
x=time.time()
print(x)
#时间字符串
y=time.strftime("%Y-%m-%d %X")
print(y)'''
#时间元组:localtime将一个时间戳转换为当前时区的struct_time #print(time.localtime())
#time.struct_time(tm_year=2017, tm_mon=7, tm_mday=24,tm_hour=13, tm_min=59, tm_sec=37, tm_wday=0, tm_yday=205, tm_isdst=0)
#时间戳是计算机能够识别的时间;时间字符串是人能够看懂的时间;元组则是用来操作时间的*****************
#三种方式之间的转换 #random模块
import random #随机数
#随机小数
'''x=random.random() #大于0且小于1之间的小数
print(x)
x1=random.uniform(12,23)#大于12小于23的小数
print(x1)
#随机整数
y=random.randint(1243,6567) #首尾都baokuo
y1=random.randrange(1,10,2) # 大于等于1且小于10之间的奇数 #不包括wei
print(y)
print(y1)
#随机选择多个返回
z=random.sample([1,'23',[4,5]],2) # #列表元素任意2个组合
print(z)
#打乱列表顺序
item=[1,23,5,7,97]
x=random.shuffle(item)
print(item)'''
#生成随机验证码 '''def v_code(): code = ''
for i in range(5): num=random.randint(0,9)
alf=chr(random.randint(65,90))
add=random.choice([num,alf])
code="".join([code,str(add)]) return code print(v_code())'''
#os模块(操作系统模块):与操作系统交互的一个接口
#sys模块:与python解释器交互的一个接口
#******
# 序列就是字符串
# 序列化的应用
# 写文件(数据传输)
# 网络传输
# 序列化模块:将原本的字典、列表等内容转换成一个字符串的过程就叫做序列化。
# 序列化:内存中的对象转换为字节序列(字符串)
# 反序列化:将字节序列转换为内存中的对象
# 序列化的目的:
# 1.以某种存储形式是自定义对象持久化
# 2.将对象从一个地方传递到另一个地方
# 3.使程序更具有维护性
#
# json模块:通用的序列化格式 只有很少的一部分数据类型通过json转化为字符串
#可以进行序列化的:数字 字符串 元组 列表 不能转集合
# 1.dumps() 序列化方法
'''dic={'a':'1',"b":'2'}
print(type(dic),dic)
import json
str_dic=json.dumps(dic)
print(type(str_dic),str_dic)
#2.loads反序列化方法
dic_d=json.loads(str_dic)
print(type(dic_d),dic_d)''' #格式化输出
'''import json
data = {'username':['李华','二愣子'],'sex':'male','age':16}
json_dic2 = json.dumps(data,sort_keys=True,indent=2,separators=(',',':'),ensure_ascii=False)
print(json_dic2)
结果;
{
"age":16,
"sex":"male",
"username":[
"李华",
"二愣子"
]
}''' #3.dump和load 不加s 和文件相关的操作
import json
# dic={'a':'1',"b":'2'}
# f=open('fff','w',encoding='utf-8')
# json.dump(dic,f)
# f.close()
# f=open('fff')
# res=json.load(f)
# print(type(res),res) # pickle模块:所有的python中的数据类型都可以转化 但只有pyth理解,且部分反序列化依赖代码
# shelve模块:序列化句柄 直接操作,方便
python中的各个模块的更多相关文章
- Python中的random模块,来自于Capricorn的实验室
Python中的random模块用于生成随机数.下面介绍一下random模块中最常用的几个函数. random.random random.random()用于生成一个0到1的随机符点数: 0 < ...
- Python中的logging模块
http://python.jobbole.com/86887/ 最近修改了项目里的logging相关功能,用到了python标准库里的logging模块,在此做一些记录.主要是从官方文档和stack ...
- Python中的random模块
Python中的random模块用于生成随机数.下面介绍一下random模块中最常用的几个函数. random.random random.random()用于生成一个0到1的随机符点数: 0 < ...
- 浅析Python中的struct模块
最近在学习python网络编程这一块,在写简单的socket通信代码时,遇到了struct这个模块的使用,当时不太清楚这到底有和作用,后来查阅了相关资料大概了解了,在这里做一下简单的总结. 了解c语言 ...
- python中的StringIO模块
python中的StringIO模块 标签:python StringIO 此模块主要用于在内存缓冲区中读写数据.模块是用类编写的,只有一个StringIO类,所以它的可用方法都在类中.此类中的大部分 ...
- python中的select模块
介绍: Python中的select模块专注于I/O多路复用,提供了select poll epoll三个方法(其中后两个在Linux中可用,windows仅支持select),另外也提供了kqu ...
- Python中的re模块--正则表达式
Python中的re模块--正则表达式 使用match从字符串开头匹配 以匹配国内手机号为例,通常手机号为11位,以1开头.大概是这样13509094747,(这个号码是我随便写的,请不要拨打),我们 ...
- python中的shutil模块
目录 python中的shutil模块 目录和文件操作 归档操作 python中的shutil模块 shutil模块对文件和文件集合提供了许多高级操作,特别是提供了支持文件复制和删除的函数. 目录和文 ...
- Python中使用operator模块实现对象的多级排序
Python中使用operator模块实现对象的多级排序 今天碰到一个小的排序问题,需要按嵌套对象的多个属性来排序,于是发现了Python里的operator模块和sorted函数组合可以实现这个功能 ...
- 【转】浅析Python中的struct模块
[转]浅析Python中的struct模块 最近在学习python网络编程这一块,在写简单的socket通信代码时,遇到了struct这个模块的使用,当时不太清楚这到底有和作用,后来查阅了相关资料大概 ...
随机推荐
- 机器学习聚类算法之DBSCAN
一.概念 DBSCAN是一种基于密度的聚类算法,DBSCAN需要两个参数,一个是以P为中心的邻域半径:另一个是以P为中心的邻域内的最低门限点的数量,即密度. 优点: 1.不需要提前设定分类簇数量,分类 ...
- php 各种扩展 - 都有
https://windows.php.net/downloads/pecl/releases/
- 七、设备驱动中的阻塞与非阻塞 IO(二)
7.2 轮询 7.2.1 介绍 在用户程序中的 select() 和 poll() 函数最终会使设备驱动中的 poll() 函数被执行. 设备驱动程序中的轮询函数原型: /** 用于询问设备是否可以非 ...
- Ubuntu下Cmake编译C++程序Helloworld
1.首选新建工程目录 mkdir helloworld 2.新建文件目录 cd helloworld mkdir bin mkdir lib mkdir src mkdir include mkdir ...
- Spring Data JPA基本了解
前言 自 JPA 伴随 Java EE 5 发布以来,受到了各大厂商及开源社区的追捧,各种商用的和开源的 JPA 框架如雨后春笋般出现,为开发者提供了丰富的选择.它一改之前 EJB 2.x 中实体 B ...
- rsync快速部署记录
rsync快速部署记录 安装rsync和使用环境:客户端:10.192.30.59 fudao_db_cluster_002 (将本地文件备份到服务端)服务端:10.192.30.60 fudao_d ...
- win2008 ad域控搭建
一.前言 1.1 AD 域服务 什么是目录(directory)呢? 日常生活中使用的电话薄内记录着亲朋好友的姓名.电话与地址等数据,它就是 telephone directory(电话目录):计算机 ...
- 安装SQL2012出现[HKLM\Software\Microsoft\Fusion!EnableLog] (DWORD)设置为 1
本人安装SQL2012出现这个错误,找了三天三夜,终于把问题找出来,共享给有需要的人们,不用重新换系统 错误如下: 1,此问题是系统.net Framework版本冲突,首先下载.net Framew ...
- 9. ClustrixDB主从复制
一.在线添加从库 主集群: 10.1.1.23:5306 从集群: 10.1.3.88:5306 主库开启binlog MySQL [(none)]> CREATE BINLOG 'clustr ...
- Java设计模式:23种设计模式全面解析(超级详细)
设计模式(Design Pattern)是前辈们对代码开发经验的总结,是解决特定问题的一系列套路.它不是语法规定,而是一套用来提高代码可复用性.可维护性.可读性.稳健性以及安全性的解决方案. 1995 ...