Collections 是 Python 内建的一个集合模块,提供了许多额外的数据类型。

namedtuple

namedtuple 主要用来生成可以使用名称来访问元素的数据对象,通常用来增强代码的可读性。

namedtuple 是一个函数,它用来创建一个自定义的 tuple 对象,并且规定了 tuple 元素的个数,可以用属性而不是索引来写入或者访问 tuple 的某个元素。

  1. >>> from collections import namedtuple
  2. >>> Point = namedtuple('Point',['x','y'])
  3. >>> p = Point(1,2)
  4. >>> print(p.x,p.y)
  5. 1 2
  6. >>> Web = namedtuple('web',['name','type','url'])
  7. >>> p1 = Web('google','search','www.google.com')
  8. >>> p2 = Web('sina','portal','www.sina.com.cn')
  9. >>> print(p1)
  10. Web(name='google',type='search',url='www.google.com')

deque

使用 list 存储数据时,按索引访问元素很快,但是插入和删除元素就很慢了,因为 list 是线性存储,数据量大的时候,插入和删除效率很低。

deque 是为了实现高效插入和删除操作的双向列表,适合用于队列和栈。

deque 在插入数据时速度比 list 快很多,当然这个是相对于存在大量数据的 list 而言的。

  1. >>> from collections import deque
  2. >>> import time
  3. >>> q = deque(['a','b','c'])
  4. >>> q.append('x')
  5. >>> q.appendleft('y')
  6. >>> print(q)
  7. deque(['y','a','b','c','x'])

对比一下 deque 和 list 的速度。对含有 1 亿个元素的 list 执行插入:

  1. >>> q0 = [x*x for x in range(100000000)]
  2. >>> a = time.time()
  3. >>> q0.insert(0,888)
  4. >>> b = time.time()
  5. >>> print(b-a)
  6. 0.09701275825500488

对含有 1 亿个元素的 deque 执行插入:

  1. >>> q1 = deque(q0)
  2. >>> a = time.time()
  3. >>> q1.appendleft(888)
  4. >>> b = time.time()
  5. >>> print(b-a)
  6. 0.0009984970092773438

defaultdict

在使用原生的 dict 的时候,如果用 d[key] 这样的方式访问,当指定的 key 不存在时,会抛出 KeyError 异常,也就是发生错误。

如果使用 defaultdict,只要你传入一个默认的方法,那么请求一个不存在的 key 时,便会调用这个方法,使用其结果来作为这个 key 的默认值。

  1. >>> from collections import defaultdict
  2. >>> i = defaultdict(lambda:100)
  3. >>> i['name']='David'
  4. >>> print(i['name'])
  5. David
  6. >>> print(i['score'])
  7. 100

OrderedDict

原生的 dict 的 key 是无序的。而使用 OrderedDict,追加一对 key value。OrderedDict 的 key 会按照插入的顺序排列。

其他的方法基本一致。

Counter

Counter 提供了一个简单的计数器功能。

  1. >>> from collections import Counter
  2. >>> s = input('Please input:')
  3. Please input:abcddeee
  4. >>> s = s.lower()
  5. >>> c = Counter(s)
  6. >>> print(c.most_common(5)) # 获取出现频率最高的5个字符
  7. [('e',3),('d',2),('b',1),('c',1),('a',1)]

Python 的 Collection 库的更多相关文章

  1. Python底层socket库

    Python底层socket库将Unix关于网络通信的系统调用对象化处理,是底层函数的高级封装,socket()函数返回一个套接字,它的方法实现了各种套接字系统调用.read与write与Python ...

  2. 【C++实现python字符串函数库】strip、lstrip、rstrip方法

    [C++实现python字符串函数库]strip.lstrip.rstrip方法 这三个方法用于删除字符串首尾处指定的字符,默认删除空白符(包括'\n', '\r', '\t', ' '). s.st ...

  3. 【C++实现python字符串函数库】二:字符串匹配函数startswith与endswith

    [C++实现python字符串函数库]字符串匹配函数startswith与endswith 这两个函数用于匹配字符串的开头或末尾,判断是否包含另一个字符串,它们返回bool值.startswith() ...

  4. 【C++实现python字符串函数库】一:分割函数:split、rsplit

    [C++实现python字符串函数库]split()与rsplit()方法 前言 本系列文章将介绍python提供的字符串函数,并尝试使用C++来实现这些函数.这些C++函数在这里做单独的分析,最后我 ...

  5. python使用cookielib库示例分享

    Python中cookielib库(python3中为http.cookiejar)为存储和管理cookie提供客户端支持,下面是使用示例 该模块主要功能是提供可存储cookie的对象.使用此模块捕获 ...

  6. Python virtualenv安装库报错SSL: CERTIFICATE_VERIFY_FAILED

    Python virtualenv安装库报错SSL: CERTIFICATE_VERIFY_FAILED 问题描述 使用pip按照virtualenv报错,如下: pip install virtua ...

  7. 【python】标准库的大致认识

    正如那句 Python 社区中很有名的话所说的:“battery included”,Python 的一大好处在于它有一套很有用的标准库(standard library).标准库是随着 Python ...

  8. Python 图形 GUI 库 pyqtgraph

    原文  Python 图形 GUI 库 pyqtgraph pyqtgraph 是纯 Python 图形 GUI 库,基于PyQT4 /pyside和NumPy.它主要目的用于在数学/科学/工程中.M ...

  9. python的urllib2库详细使用说明

    一直以来技术群里会有新入行的同学提问关于urllib和urllib2以及cookielib相关的问题.所以我打算在这里总结一下,避免大家反复回答同样的问题浪费资源. 这篇属于教程类的文字,如果你已经非 ...

随机推荐

  1. ansible简要说明

    说明 Ansible是一个python编写模型驱动的配置管理器,支持多节点发布.远程任务执行.默认使用 SSH 进行远程连接.无需在被管理节点上安装附加软件,可使用各种编程语言进行扩展.本文基于ans ...

  2. js 简单实现隐藏和显示

    <html> <head> <meta charset="gb2312"> <title>隐藏和显示</title> & ...

  3. jenkins插件管理提示“update information obtained:不可用ago”

    jenkins插件管理遇到两个错误 (1)插件管理页面提示:There were errors checking the update sites:IOException:Unable to tunn ...

  4. Fatal Error: Out of memory php内存溢出处理三种方法

    有时候我们在运行php程序的时候会发现 Fatal Error: Out of memory 这样的提示,这有可能是程序中用到了大量了变量和对象,导致分配的内存不够用. 修改php.ini文件里的me ...

  5. GridView设置右键菜单

    一.控件设定: 1.页面添加ContextMenuStrip控件: 2.ContextMenuStrip添加菜单项: 3.gridControl找到ContextMenuStrip属性,设置成刚添加C ...

  6. PuppeteerSharp体验之旅

    public static async Task<string> LogInAsync() { try { string ResultCookies = ""; //获 ...

  7. QT:如何重新生成makefile文件

  8. jquery timeStamp属性 语法

    jquery timeStamp属性 语法 作用:timeStamp 属性包含从 1970 年 1 月 1 日到事件被触发时的毫秒数.直线模组 语法:event.timeStam 参数: 参数 描述 ...

  9. CGI中使用Cookie

    在 http 协议一个很大的缺点就是不对用户身份的进行判断,这样给编程人员带来很大的不便, 而 cookie 功能的出现弥补了这个不足. cookie 就是在客户访问脚本的同时,通过客户的浏览器,在客 ...

  10. poj 2187 Beauty Contest 凸包模板+求最远点对

    题目链接 题意:给你n个点的坐标,n<=50000,求最远点对 #include <iostream> #include <cstdio> #include <cs ...