zoukankan      html  css  js  c++  java
  • python基础知识4——collection类——计数器,有序字典,默认字典,可命名元组,双向队列

    1、计数器(counter)

    Counter是对字典类型的补充,用于追踪值的出现次数。

    ps:具备字典的所有功能 + 自己的功能

     Counter

    我们从中挑选一些相对常用的方法来举例:

    在上面的例子我们可以看出,counter方法返回的是一个字典,它将字符串中出现的所有字符都进行了统计。在这里再介绍一下update方法,这个update方法是将两次统计的结果相加,和字典的update略有不同。

    2、有序字典(orderedDict )

    orderdDict是对字典类型的补充,他记住了字典元素添加的顺序

     OrderedDict

            我们都知道字典本来是无序的,它依靠key,value之间的索引进行匹配,那么有序字典的原理是什么呢? 原理: dic = {'k2':1,'k1':2},li = ['k1','k2'],这个字典在内部维护了一个key列表。

     

    从上面的图中我们就知道,尽管我们定义的字典是从1到8按顺序写的,但是在打印的过程当中并没有按到我们希望的顺序打印。这个时候有序字典的优势就出来了:

    3、默认字典(defaultdict) 

    学前需求:

    1 有如下值集合 [11,22,33,44,55,66,77,88,99,90...],将所有大于 66 的值保存至字典的第一个key中,将小于 66 的值保存至第二个key的值中。
    2 即: {'k1': 大于66 , 'k2': 小于66}
     原生字典解决方法
     defaultdict字典解决方法

    defaultdict是对字典的类型的补充,他默认给字典的值设置了一个类型。

     defaultdict

    4、可命名元组(namedtuple) 

    根据nametuple可以创建一个包含tuple所有功能以及其他功能的类型。

    1 import collections
    2  
    3 Mytuple = collections.namedtuple('Mytuple',['x', 'y', 'z'])
     Mytuple

    主要用于‘坐标’的表示。用法如下:

    5、双向队列(deque)

    一个线程安全的双向队列

     deque

    注:既然有双向队列,也有单项队列(先进先出 FIFO )

     Queue.Queue

    一个线程安全的双向队列:双向队列我们可以理解为两个栈底相连的栈,和队列的先进先出不同,元素可以从这个队列的两端分别加入或者删除值。尽管list其实完全可以实现这个功能,但是python的collections类还是很贴心的把这些方法都归纳了出来,歪果仁就是有意思啊~~~

     deque Code

     

  • 相关阅读:
    函数柯里化
    常用正则
    校验table行内的form编辑
    前端代码 读取excel表格数据
    cocos2d-x 帧动画学习
    Linux 下vim配置
    Android开发笔记 二
    cocos2d-x CCDictionary类学习
    Android开发笔记
    Cococs2d-x移植到Window下的问题
  • 原文地址:https://www.cnblogs.com/zhenghaonihao/p/6214564.html
Copyright © 2011-2022 走看看