python collection模块
一、模块的认识
定义:模块就是我们把装有特定功能的代码进行归类的结果。
说明:从代码编写的单位来看我们的城西,从小到大:一条代码 -> 语句块 - >代码块(函数、类)-> 模块。
模块引入的方法:
1、import 模块
2、from xxx import 模块
二、collections模块
collectionz模块中主要封装了一些关于集合类的相关操作,比如之前学过的Iterable,Iterator等等,今日主要记录的是Couter,deque,OrderDict,defaultdict,defaultdict以及namedtuple.
(1)Couter
Couter时一个计数器,主要用于计数.
# 计算字符串中每个元素出现的次数
# 普通方法
str="alex like pig"
dic={}
for el in str:
dic[el]=dic.setdefault(el,)+
print(dic)
# 借用collections模块中 的Counter(计数器)
str="alex like pig"
import collections
print(collections.Counter(str)) from collections import Counter
c=Counter(str)
print(Counter(c)) # 获取到的结果可以像字典⼀样进⾏使⽤ [key]
(2)deque 双向队列
1. 栈: FILO. 先进后出 -> 砌墙的砖头, 老师傅做馒头
# 栈 track (先进后出)
class TrackFullError(Exception):
pass
class TrackEmptyError(Exception):
pass
class Track:
def __init__(self,size):
self.index=0
self.lst=[]
self.size=size def push(self,item):
'''
入栈
:param item: 入栈元素
:return:
'''
if self.index>4:
raise TrackFullError("Track is Full")
self.lst.insert(self.index,item)
self.index+=1
print(self.lst)
def pop(self):
'''
出栈
:return:
'''
self.index-=1
if self.index<0:
raise TrackEmptyError("Track is Empty")
item=self.lst.pop(self.index)
print(item)
2. 队列: FIFO. 先进先出 -> 买火⻋票排队, 所有排队的场景
注意. 如果队列⾥没有元素了. 再也就拿不出来元素了. 此时程序会阻塞
#队列queue (先进先出)
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()) 队列里面没有元素,会等待,不报错
双向队列 :deque
说明:既能从左进,也能从右进;既能从左边出也能从右边出。
from collections import deque c=deque()
c.append("风") #从右侧开始添加
c.append("雨")
c.appendleft("电") #从左侧开始添加
c.appendleft("雷") print(c) #deque(['雷', '电', '风', '雨'])
print(c.pop()) #从右侧开始弹出
print(c.pop())
print(c.popleft())
print(c.popleft())#从左侧开始弹出
print(c.popleft()) #IndexError: pop from an empty deque
(3)命名元组 namedtuple
命名元组:本质就是一个元组,命名元祖可以进行解包。
# # 命名元祖 namedtuple 终归是一个元祖,不能更改
from collections import namedtuple
point=namedtuple("点",["x","y"])
p=point(5,10)
print(p)
print(p.x)
print(p.y)
# p.x=10 #can't set attribute
# p.z=16 #AttributeError: '点' object has no attribute 'z'
(4)defaultdict 字典默认值
默认值 defaultdict执行流程:
1、defaultdict中必须是一个可以被调用的对象;
2、如果存在key,返回相应的value,如果不存在则执行可调用对象,并吧结果返回
from collections import defaultdict
# d=defaultdict(list)
# print(d["华辣汤"])#当defaultdict中不存在"华辣汤",则执行了list( )
(5)orderdict和defaultdict
orderdict 顾名思义. 字典的key默认是⽆序的. ⽽OrderedDict是有序的 ,但是从python3.6以后的版本
,我们看到的字典都是有序的。
python collection模块的更多相关文章
- Python collection模块与深浅拷贝
collection模块是对Python的通用内置容器:字典.列表.元组和集合的扩展,它包含一些专业的容器数据类型: Counter(计数器):dict子类,用于计算可哈希性对象的个数. Ordere ...
- Python进阶(十)----软件开发规范, time模块, datatime模块,random模块,collection模块(python额外数据类型)
Python进阶(十)----软件开发规范, time模块, datatime模块,random模块,collection模块(python额外数据类型) 一丶软件开发规范 六个目录: #### 对某 ...
- python双端队列-collection模块
双端队列(double-ended queue,或者称deque)在需要按照元素增加的顺序来移除元素时非常有用.其中collection模块,包括deque类型. 使用实例:
- day0320 时间模块 collection模块
一. TIME模块 python提供了一个time和calendar模块可以用于格式化日期和时间. 时间间隔一秒为单位. 每个时间戳都以1970年1月1日午夜经过多长时间来表示. 1.时间戳 函数ti ...
- what's the python之模块
正则表达式 首先,我们引入了正则表达式的知识.所谓正则表达式,就是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符.及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对 ...
- day 20 collection模块 time 模块 os 模块
一.collection模块 1.namedtuple: 生成可以使用名字来访问元素内容的tuple 2.deque: 双端队列,可以快速的从另外一侧追加和推出对象 3.Counter: 计数器,主要 ...
- python 之模块之 xml.dom.minidom解析xml
# -*- coding: cp936 -*- #python 27 #xiaodeng #python 之模块之 xml.dom.minidom解析xml #http://www.cnblogs.c ...
- Python标准模块--threading
1 模块简介 threading模块在Python1.5.2中首次引入,是低级thread模块的一个增强版.threading模块让线程使用起来更加容易,允许程序同一时间运行多个操作. 不过请注意,P ...
- Python的模块引用和查找路径
模块间相互独立相互引用是任何一种编程语言的基础能力.对于“模块”这个词在各种编程语言中或许是不同的,但我们可以简单认为一个程序文件是一个模块,文件里包含了类或者方法的定义.对于编译型的语言,比如C#中 ...
随机推荐
- win10 uwp 商业游戏 1.2.1
上一个游戏已经告诉大家如何写多个游戏,现在继续写这个无聊的游戏 希望大家在看这篇文章之前先看win10 uwp 商业游戏,在这个文章告诉了大家如何创建游戏. 修改数值 可以从上一篇的博客的游戏看到升级 ...
- vue+elementUI项目,父组件向子组件传值,子组件向父组件传值,父子组件互相传值。
vue+elementUI项目,父组件向子组件传值,子组件向父组件传值,父子组件互相传值. vue 父组件与子组件相互通信 一.父组件给子组件传值 props 实现父组件向子组件传值. 1父组件里: ...
- The JRE_HOME environment variable is not defined correctly This environment
昨天启动tomcat还好好的,今天不知道抽什么风,cmd中报错: The JRE_HOME environment variable is not defined correctly This env ...
- Docker命令行与守护进程如何交互?
译者按: Docker是典型的C/S架构,其守护进程(daemon)与命令行(CLI)是通过REST API进行交互的. 原文: Understanding how the Docker Daemon ...
- vue从入门到进阶:vue-router路由功能(九)
基本使用 html: <script src="https://unpkg.com/vue/dist/vue.js"></script> <scrip ...
- loj#6029. 「雅礼集训 2017 Day1」市场(线段树)
题意 链接 Sol 势能分析. 除法是不能打标记的,所以只能暴力递归.这里我们加一个剪枝:如果区间内最大最小值的改变量都相同的话,就变成区间减. 这样复杂度是\((n + mlogn) logV\)的 ...
- CentOS-7.2安装Ambari-2.6.1
CentOS-7.2安装Ambari-2.6.1 一.Ambari 是什么? Ambari 跟 Hadoop 等开源软件一样,也是 Apache Software Foundation 中的一个项目, ...
- Linux扩展分区记录
Vmware中新建的Linux虚拟机,数据盘规划太小,数据量超出磁盘大小,本文介绍如何快速扩充空间 参考:https://blog.csdn.net/lyd135364/article/details ...
- 小技巧:在线生成按钮Shape的网站
AndroidButton Make 右侧设置按钮的属性,可以即时看到效果,并即时生成对应的.xml 代码,非常高效(当然熟练的话 自己手写代码更快)
- wap2app(二)-- 设置APP系统状态栏
准备 工具:HBuilder 一.全屏设置,不显示系统状态栏 这里所说的系统状态栏就是包括了:信号.运营商.电量等信息手机屏幕最顶部信息. 全屏并非状态栏透明或变色,而是没有状态栏,也就是看不见电量. ...