一、分别取出大于66的数字和小于66的数字

小练习:需求要求有一个列表列表中存着一组数字,要求将大于66的数字和小于66的数字分别取出来

aa = [11,22,33,44,55,66,77,88,99,90]

dic = {}

for i in aa :

    ifi <= 66 :

        if 'k1' in dic.keys():

            dic['k1'].append(i)

        else:

            #创建只有一项元素的列表

          
dic['k1'] = [i,]   #为了规范请使用逗号

    else:

        if 'k2' in dic.keys():

            dic['k2'].append(i)

        else:

            dic['k2'] = [i,]

print(dic['k1'])

print(dic['k2'])

#k1和k2就分别保存了大于66和小于66的结果

 

二、collections系列

(1)Counter计数器

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

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

例子:
import collections
f1 = collections.Counter('asdwqewqdsadsadsa')
print(f1)
结果:
Counter({'a': 4, 'd': 4, 's': 4, 'q': 2, 'w': 2, 'e': 1})
#这个例子就是统计出元素出现的次数

2)有序字典class OrderedDict(dict):

orderdDict是对字典类型的补充,他记住了字典元素添加的顺序,从而使字典变得有序

例子:

import collections
f1 = collections.OrderedDict()
f1["a"] = 3
f1["c"] = 2
f1["b"] = 1
f2 = {}
f2["a"] = 3
f2["c"] = 2
f2["b"] = 1
print(f1,f2)

结果:OrderedDict([('a', 3), ('c', 2), ('b', 1)]) {'b': 1, 'c': 2, 'a': 3}

从上面就可以发现,想同值的字典使用OrderedDict就按照添加顺序进行排序

内部机制:

在正常的字典中f2这么排序的:

f2 = {'b': 1, 'c': 2, 'a': 3}

而使用OrderedDict后他会生成一个列表来保存字典添加的顺序

f1 = {'b': 1, 'c': 2, 'a': 3}

f1_list = ["a","c","b"]

这样就可以通过for循环来得到有序的字典

不要较真哈

(3)默认字典(defaultdict)

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

import collections
f1 = collections.defaultdict(list)
f1["a"].append(1)
print(f1)
上面的和下面的效果相等,所以defaultidict是把value值设置成默认为list类型也就是列表类型
f1 = {}
f1["a"] = []
f1["a"].append(1)
(4)可命名元组namedtuple

也就是将值提前起个名字,然后传值,主要用于平面图想x,y轴

import collections

atuple = collections.namedtuple("atuple",['x','y','z'])
new = atuple(1,2,3,)
print(new)
atuple(x=1, y=2, z=3)
(5)双向队列collections.deque

双向队列为,例如有一个列表,这个列表呢 可以从左面和右面取数据,也可以从左面和右面同时加数据

方法:

(1)def append(self, *args, **kwargs): 添加右侧
      # real signature unknown
           """ Add an element to the right side of the dequ
‘. """
           
pass
(2)def appendleft(self, *args, **kwargs): 添加到队列的左侧
           # real signature unknown
            """ Add an element to the left side of the deque. """
            
pass
(3)clear(self, *args, **kwargs): 清除
  real signature unknown
   "" Remove all elements from the deque. """
   
ass
(4)f count(self, value): 元素出现的的个数
   real signature unknown; restored from __doc__
     """ D.count(value) -> integer -- return number of occurrences of value """
    
return 0
(5)def extend(self, *args, **kwargs):扩展右添加
   # real signature unknown
     """ Extend the right side of the deque with elements from the iterable
"""
    
pass
(6)def extendleft(self, *args, **kwargs): 扩展左添加
    # real signature unknown
     """ Extend the left side of the deque with elements from the iterable """
    
pass
(7)def pop(self, *args, **kwargs): 从右侧取出元素
   # real signature unknown
     """ Remove and return the rightmost element. """
    
pass
(8)def popleft(self, *args, **kwargs):从左侧取出元素
    real signature unknown
     """ Remove and return the leftmost element. """
    
pass
(9)def remove(self, value): 删除指定元素
   # real signature unknown; restored from __doc__
     """ D.remove(value) -- remove first occurrence of value. """
    
pass
(10)def reverse(self): 翻转
    # real signature unknown; restored from __doc__
     """ D.reverse() -- reverse *IN PLACE* """
    
pass

三、单向队列Queue

    q =Queue.Queue(10) 创建单向队列,括号中为队列中可放入元素的个数
    q.put 添加元素
    q.get 取出元素
  • 队列的特点:谁先进入谁先出去
  • 栈的特点:弹夹结构,后加的先出

python成长之路第二篇(4)_collections系列的更多相关文章

  1. Python成长之路第二篇(1)_数据类型内置函数用法

    数据类型内置函数用法int 关于内置方法是非常的多这里呢做了一下总结 (1)__abs__(...)返回x的绝对值 #返回x的绝对值!!!都是双下划线 x.__abs__() <==> a ...

  2. Python成长之路第二篇(3)_字典的置函数用法

    字典的置函数用法(字典dict字典中的key不可以重复) class dict(object): """ dict() -> new empty dictionar ...

  3. Python成长之路第二篇(2)_列表元组内置函数用法

    列表元组内置函数用法list 元组的用法和列表相似就不一一介绍了 1)def append(self, p_object):将值添加到列表的最后 # real signature unknown; r ...

  4. Python人工智能之路 - 第二篇 : 算法实在太难了有现成的直接用吧

    本节内容 预备资料: 1.FFmpeg: 链接:https://pan.baidu.com/s/1jonSAa_TG2XuaJEy3iTmHg 密码:w6hk 2.baidu-aip: pip ins ...

  5. Python成长之路第一篇(4)_if,for,while条件语句

    有了以上的基本基础,已经上面写的几个小练习,大家肯定有很多的不满,比如查询为什么查询一次就退出了呢?下面我们来学习条件语句 一.万恶的加号 以前我们在print的时候如果要加上变量都有是使用+来作为连 ...

  6. Python成长之路第一篇(2)-初识列表和元组

    可以将列表和元组当成普通的“数组”,他能保存任意数量任意类型的Python对象,和数组一样都是通过数字0索引访问元素,列表和元组可以存储不同类型的对象,列表和元组有几处重要区别.列表元素用([])包括 ...

  7. 我的Python成长之路---第二天---Python基础(7)---2016年1月9日(晴)

    再说字符串 一.字符串的编码 字符串的编码是个很令人头疼的问题,由于计算机是美国人发明的,他们很理所当然的认为计算机只要能处理127个字母和一些符号就够用了,所以规定了一个字符占用8个比特(bit)也 ...

  8. Python成长之路第一篇(2)__初识列表和元组

    可以将列表和元组当成普通的“数组”,他能保存任意数量任意类型的Python对象,和数组一样都是通过数字0索引访问元素,列表和元组可以存储不同类型的对象,列表和元组有几处重要区别.列表元素用([])包括 ...

  9. python成长之路第一篇(5)文件的基本操作

    一.三元运算 我们在上章学习的if,,else,,有一种简便的方法 他的表达式是这样的:变量 = 值1 if 条件 else 值2 解释过来就是如果aaa等于sss则输出值1否则输出值2 二.类的概念 ...

随机推荐

  1. 前端开发者使用JS框架的三个等级

    目前前端开发者使用JS框架是种很普遍的现象,因为框架可以加快开发速度,同时避免各类浏览器的兼容性问题.不过同样是用框架开发,不同开发者的境界水平还是有一定差距,本文将这些前端开发者分为三个等级. 第一 ...

  2. Json对象在JS里面的处理

    1.遍历Json对象 myJson = {"name":"nikita", "password":"1111"}; fo ...

  3. DataSnap

    一. DataSnap REST - http://docwiki.embarcadero.com/RADStudio/Berlin/en/DataSnap_REST 1. URI Mapping: ...

  4. sql中插入多条记录-微软批处理

    这是使用批处理的一个例子: System.IO.StreamWriter messagelog = null; string messageString = ""; SqlConn ...

  5. javascript加载优化

    当加载js时,页面会一直在转,没有加载完. 如何优化这一点呢 js的加载方式介绍 同步加载---------------异步加载------------------延迟加载 异步加载仍然会触发wind ...

  6. jQuery插件之Form

    一.jQuery.Form.js 插件的作用是实现Ajax提交表单. 方法: 1.formSerilize() 用于序列化表单中的数据,并将其自动整理成适合AJAX异步请求的URL地址格式. 2.cl ...

  7. Asp.net 处理程序(第五篇)

    HttpApplication有19个标准事件,当到达第8个事件PostMapRequestHandler触发的时候,标志着已经获取到了处理请求的处理程序对象,在第11个事件PreRequestHan ...

  8. C语言的本质(34)——静态库

    库是一种软件组件技术,库里面封装了数据和函数. 库的使用可以使程序模块化. Windows系统包括静态链接库(.lib文件)和动态链接库(.dll文件). Linux通常把库文件存放在/usr/lib ...

  9. 【转】 linux内核移植和驱动添加(三)

    原文网址:http://blog.chinaunix.net/uid-29589379-id-4708909.html 原文地址:linux内核移植和驱动添加(三) 作者:genehang 四,LED ...

  10. java_IO流之 NIO

    NIO 定义 即新IO,在JDK1.4的java.nio.*包中引入,其目的在于提高速度. 在Java1.4之前的I/O系统中,提供的都是面向流的I/O系统,系统一次一个字节地处理数据,一个输入流产生 ...