python常用数据结构
0. 字典初始化
d = {‘a’:1,’b’:2}
或 d={}
d[‘a’] = 1
d[‘b’] = 2
是不是和json格式数据很相似,语法和JavaScript又很相似
1. 变量接受序列分解:
p = (3.14,8.23)
X,Y = p
print(x,y)
3.14,8.23
2. Collections.deque 固定长度队列。
>>> from collections import deque
>>> p = deque(maxlen = 2)
>>> p.append(3.14)
>>> p.append(8.23)
>>> p
deque([3.14, 8.23], maxlen=2)
3. heapq 最大值最小值。
>>> import heapq
>>> p = [3.14,8.23,7.10]
>>> heapq.nlargest(1,p)
[8.23]
>>> heapq.nsmallest(1,p)
[3.14]
5.找出两个字典相同键 和相同项
>>> from collections import OrderedDict
>>> d = {}
>>> d['a'] = 1
>>> d['c'] = 3
>>> d['b'] = 2
>>> dd = {}
>>> dd['a'] = 3
>>> dd['e'] = 5
>>> dd['b'] = 2
>>> d.keys() & dd.keys()
{'a', 'b'}
>>> d.items() & dd.items()
{('b', 2)}
6 去除数组或字典值重复的元素 set
>>> d ={1,1,2,2,3,3,4,5}
>>> set(d)
{1, 2, 3, 4, 5}
7 截取数组元素
>>> d = [1,1,2,2,3,3,4,5]
>>> d[2:4]
[2, 2]
>>> d[2:5]
[2, 2, 3]
8 统计元素出现次数Counter.most_common。
>>> d = [1,1,1,2,2,4,5]
>>> from collections import Counter
>>> master = Counter(d).most_common(2)
>>> print(master)
[(1, 3), (2, 2)]
4. collections.OrderedDict 有序字典
>>> from collections import OrderedDict
>>> d = OrderedDict()
>>> d['a'] = 1
>>> d['c'] = 3
>>> d['b'] = 2
>>> print(d)
OrderedDict([('a', 1), ('c', 3), ('b', 2)])
9.数组排序 operator.itemgetter
>>> from operator import itemgetter
>>> d = [2,1,5,4,3]
>>> sorted(d)
[1, 2, 3, 4, 5]
10.字典排序 sort
>>> from operator import itemgetter
>>> p = [{'x':'3','y':'3'},{'x':'4','y':'4'},{'x':'2','y':'2'},{'x':'1','y':'1'}]
>>> p.sort(key=itemgetter('x'))
>>> print(p)
[{'x': '1', 'y': '1'}, {'x': '2', 'y': '2'}, {'x': '3', 'y': '3'}, {'x': '4', 'y': '4'}]
11. lambda 表达式
>>> p = [{'x':'3','y':'3'},{'x':'4','y':'4'},{'x':'2','y':'2'},{'x':'1','y':'1'}]
>>> pLamb = [n['x'] > '2' for n in p]
>>> print(pLamb)
[True, True, False, False]
12 compress 与 11项 结合使用。
>>> from itertools import compress
>>> list(compress(p,pLamb))
[{'x': '3', 'y': '3'}, {'x': '4', 'y': '4'}]
13.逻辑上合并对象
>>> p = {'x':1,'y':2}
>>> p2 = {'y':3,'z':4}
>>> from collections import ChainMap
>>> c = ChainMap(p,p2)
>>> print(c)
ChainMap({'x': 1, 'y': 2}, {'y': 3, 'z': 4})
>>> list(c.keys())
['x', 'z', 'y']
python常用数据结构的更多相关文章
- python常用数据结构讲解
一:序列 在数学上,序列是被排成一排的对象,而在python中,序列是最基本的数据结构.它的主要特征为拥有索引,每个索引的元素是可迭代对象.都可以进行索引,切片,加,乘,检查成员等操作.在py ...
- Python常用数据结构之collections模块
Python数据结构常用模块:collections.heapq.operator.itertools collections collections是日常工作中的重点.高频模块,常用类型由: 计数器 ...
- Python常用数据结构之heapq模块
Python数据结构常用模块:collections.heapq.operator.itertools heapq 堆是一种特殊的树形结构,通常我们所说的堆的数据结构指的是完全二叉树,并且根节点的值小 ...
- python常用数据结构(1)
python中有四种最常用的数据结构,分别是列表(list),字典(dict),集合(set)和元组(tuple) 下面简单描述下它们的区别和联系 1.初始化 不得不说,python数据结构的初始化比 ...
- Python常用数据结构(列表)
Python中常用的数据结构有序列(如列表,元组,字符串),映射(如字典)以及集合(set),是主要的三类容器 内容 序列的基本概念 列表的概念和用法 元组的概念和用法 字典的概念和用法 各类型之间的 ...
- python 常用数据结构使用
python 字典操作 http://www.cnblogs.com/kaituorensheng/archive/2013/01/24/2875456.html python 字典排序 http:/ ...
- python常用数据结构的常用操作
作为基础练习吧.列表LIST,元组TUPLE,集合SET,字符串STRING等等,显示,增删,合并... #===========List===================== shoplist ...
- python 常用数据结构
#coding=utf- #元组,不可变序列(,) a=(,,,) print(a) a=tuple([,,,])#第二种定义方式 print(a) print(a[]) print(a[:]) #可 ...
- python常用数据结构(2)
1.有名字的元组——namedtuple >>> from collections import namedtuple >>> Point = namedtuple ...
- 学Python常用数据结构之字典
迄今为止,我们已经为大家介绍了Python中的三种容器型数据类型,但是这些数据类型还不足以帮助我们解决所有的问题.例如,我们要保存一个人的信息,包括姓名.年龄.体重.单位地址.家庭住址.本人手机号.紧 ...
随机推荐
- 什么是GUID?
定义及格式 1.全局唯一标识符(GUID,Globally Unique Identifier)是一种由算法生成的二进制长度为128位的数字标识符.GUID主要用于在拥有多个节点.多台计算机的网络或系 ...
- Python3处理HTML获取所需内容
处理HTML页面,经常使用的便是使用beautifulsoup库 pip install beautifulsoup4 执行上述语句下载bs4库 一般请求下来的所需数据都位于tbody的tr标签里,下 ...
- 2017web前端面试总结
2017web前端面试总结 从今年3月份开始面试笔试找实习找校招到现在也半年多了,拿到了不少offer,也有了自己的一点心得体会,这里写出来分享一下,拙见勿喷. 注意一下,以下的观点仅代表我个人的体会 ...
- 写出易于调试的SQL
1.前言 相比高级语言的调试如C# , 调试SQL是件痛苦的事 . 特别是那些上千行的存储过程, 更是我等码农的噩梦. 在将上千行存储过程的SQL 分解到 C# 管理后, 也存在调试的不通畅, 如何让 ...
- JavaScript 中的对象引用
ECMAScirpt 变量有两种不同的数据类型:基本类型,引用类型.也有其他的叫法,比如原始类型和对象类型,拥有方法的类型和不能拥有方法的类型,还可以分为可变类型和不可变类型,其实这些叫法都是依据这两 ...
- C++ 空间配置器(allocator)
C++ 空间配置器(allocator) 在STL中,Memory Allocator 处于最底层的位置,为一切的 Container 提供存储服务,是一切其他组件的基石.对于一般使用 STL 的用户 ...
- shadow dom 隔离代码 封装
Shadow DOM是指浏览器的一种能力,它允许在文档(document)渲染时插入一棵DOM元素子树,但是这棵子树不在主DOM树中. Shadow DOM 解决了 DOM 树的封装问题. ...
- sass学习--安装ruby
1.下载ruby:https://rubyinstaller.org/downloads/ 2.安装完ruby之后,在开始菜单中,找到刚才我们安装的ruby,打开Start Command Promp ...
- nova创建虚拟机源码分析系列之七 传入参数转换成内部id
上一篇博文将nova创建虚机的流程推进到了/compute/api.py中的create()函数,接下来就继续分析. 在分析之前简单介绍nova组件源码的架构.以conductor组件为例: 每个组件 ...
- php正则表达式,在抓取内容进行匹配的时候表现不稳定
最近做了一个 抓取内容的程序,使用php的正则表达式对抓取的内容进行匹配,当进行大量匹配运算的时候,发现偶尔会出现匹配失败的情况.检查不出任何原因. 匹配失败导致匹配结果为空,最终导致写入数据库失败. ...