Python中列表、字典、元组数据结构的简单学习笔记


Posted in Python onMarch 20, 2016

列表

列表是Python中最具灵活性的有序集合对象类型。与字符串不同的是,列表可以包含任何类型的对象:数字、字符串甚至其他列表。列表是可变对象,它支持原地修改的操作。

Python的列表是:

  • 任意对象的有序集合
  • 通过偏移读取
  • 可变长度、异构以及任意嵌套
  • 属于可变序列的分类
  • 对象引用数组(列表中的存储的是对象的引用,而不是对象的拷贝)

实际应用中的列表

>>基本列表操作
由于列表是序列,它支持很多与字符串相同的操作。列表对”+”和”*“操作的响应与字符串很相似,两个操作的意思也是合并和重复,只不过是一个新的列表,而不是一个字符串。

>>索引、分片和矩阵
对于列表而言,索引和分片操作与字符串中的操作基本相同。然而对列表进行索引的结果就是你指定的偏移处的对象(不管是什么类型),而对列表分片时往往返回一个新的列表。

matrix = [[1,2,3],[4,5,6],[7,8,9]]

上述代码定义了一个3*3的二维矩阵。

>>原处修改列表
索引与分片的赋值

当使用列表的时候,可以将它赋值给一个特定项(偏移)或整个片段(分片)来改变它的内容,索引和分片的赋值都是原地修改,它们对列表进行直接修改,而不是生成一个新的列表作为结果.Python中的索引赋值与C及大多数其他语言极为相似——Python用一个新值取代指定偏移的对象引用

列表方法的调用

最常用的列表方法是append,它能够简单地将一个单项(对象引用)加至列表末端。与合并不同的是,append允许传入单一对象而不是列表。L.append(X)与L+[X]的结果类似,不同的是,前者会原地修改L,而后者会生成新的列表。 另一个比较常用的方法就是sort,它原地对列表进行排序。sort是使用Python标准的比较检验作为默认值(在这里指字符串比较),而且以递增的顺序进行排序。另外,我们可以通过传入一个关键字参数来修改排序行为——这是指定按名称传递的函数调用中特殊的”name=value”语言。

需要注意的是:要当心append和sort是原地修改列表对象的,方法的返回结果并没有返回列表(从技术上讲,两者的返回值都是None)。如果编写类似L=L.append(X)的语句,将不会得到修改后的值(实际上,会失去整个列表的引用)。

  • reverse:原地反转列表
  • extend:在末端插入多个元素
  • pop:删除最后一个元素,同时返回被删除的值
  • remove:通过值删除某个元素
  • insert:在偏移处插入某个元素
  • index:查找某元素的偏移

字典

如果把列表看做是有序的对象集合,那么就可以把字典当成是无序的集合,它们主要的差别就在于:字典当中的元素师通过键来存取的,而不是通过偏移存取。 Python字典的主要属性如下:

  • 通过键而不是偏移来读取
  • 任意对象的无序集合
  • 可变长、异构、任意嵌套
  • 属于可变映射类型
  • 对象引用表(散列表)(字典中的存储的是对象的引用,而不是对象的拷贝)
  • 实际应用中的字典

>>原处修改字典
与列表相同,向字典中已存在的索引值赋值会改变与索引相关联的值。然而,与列表不同的是,每当对新字典键进行赋值(之前没有被赋值的键),就会在字典内生成一个新的元素。

>>其他字典的方法

  • keys:返回字典的键列表
  • values:返回字典的值列表
  • items:返回字典的(key,value)对元组
  • update:合并
  • pop:从字典中删除一个键并返回它的值

>>字典用法注意事项

  • 序列运算无效
  • 对新索引赋值会添加项
  • 键不一定总是字符串

>>创建字典的其他方法

#Method1
D = {'name':'mel','age':45}
#Method2
D = {}
D['name']='mel'
D['age']=45
#Method3
D = dict(name='mel',age=45)
#Method4
D = dict([('name','mel'),('age',45)])

以上四种形式都会建立相同的字典。

>>Python3.0中的字典变化
字典的功能在Python3.0中已经有所变化了,具体来说,Python3.0中的字典:

  • 支持一种新的字典解析表达式,这是列表和集合解析的”近亲”
  • 对于D.key,D.values和D.items方法,返回可迭代的视图,而不是列表
  • 由于前面一点,需要新的编码方式通过排序键来遍历
  • 不再直接支持相对大小比较——取而代之的是手动比较
  • 不再有D.has_key方法——相反,使用in成员关系测试

字典视图

在Python3.0中,字典的keys、values和items都返回视图对象,而在Python2.6中,它们返回实际的结果列表。Python3.0中的字典视图并非创建后不能改变,它们可以动态地反映在视图对象创建之后对字典做出点修改:

D={'a':1,'b':2,'c':3}
K = D.keys()
V = D.values()
del D['b']
list(K)

上述代码中,最后一行的结果是[‘a','c']。

keys方法所返回的对象类似于集合,并且支持交集和并集等常见的操作;values视图不是这样,因为它们不是唯一的;但items结果是的,如果(key,value)对是唯一的并且可散列的话。

元组

元组由简单的对象构成。元组与列表非常类似,只不过元组不能再原处修改(它们是不可变的),通常是写成圆括号(而不是方括号)中一系列项。它的属性有:

  • 任意对象的有序集合
  • 通过偏移存取
  • 属于不可变序列类型
  • 固定长度、异构、任意嵌套
  • 对象引用的数组

>>实际应用中的元组

元组的特殊语法:逗号和圆括号

因为圆括号也可以把表达式括起来,如果圆括号里的单一对象时元组对象而不是一个简单的表达式,需要对Python进行特别说明。如果确实想得到一个元组,只要在这一单个元素之后、关闭圆括号之前加上一个逗号就可以了。

x = (40)
y = (40,)

上述代码中,第一行的x是一个整数,第二行的y则是一个包含了一个元素40的元组。

转换、方法以及不可变性

元组的操作和字符串及列表是一致的,值得注意的区别在于”+”、”*“以及分片操作应用于元组时将返回新元组,并且元组不提供字符串、列表和字典中的方法。

>>为什么有了列表还要元组
元组的不可变性提供了某种完整性,这样你可以确保元组在程序中不会被另一个引用修改,而列表就没有这样的保证了。

Python 相关文章推荐
Python算法之栈(stack)的实现
Aug 18 Python
Python压缩和解压缩zip文件
Feb 14 Python
python学习之面向对象【入门初级篇】
Jan 21 Python
Python numpy生成矩阵、串联矩阵代码分享
Dec 04 Python
Python SVM(支持向量机)实现方法完整示例
Jun 19 Python
详解pandas安装若干异常及解决方案总结
Jan 10 Python
计算机二级python学习教程(3) python语言基本数据类型
May 16 Python
python 设置输出图像的像素大小方法
Jul 04 Python
用python生成与调用cntk模型代码演示方法
Aug 26 Python
PyTorch 普通卷积和空洞卷积实例
Jan 07 Python
pycharm导入源码的具体步骤
Aug 04 Python
scrapy中如何设置应用cookies的方法(3种)
Sep 22 Python
Python的Socket编程过程中实现UDP端口复用的实例分享
Mar 19 #Python
使用Python编写基于DHT协议的BT资源爬虫
Mar 19 #Python
浅析Python基础-流程控制
Mar 18 #Python
浅析Python编写函数装饰器
Mar 18 #Python
python正则表达式之作业计算器
Mar 18 #Python
基于python yield机制的异步操作同步化编程模型
Mar 18 #Python
理解Python中的With语句
Mar 18 #Python
You might like
for循环连续求和、九九乘法表代码
2012/02/20 PHP
PHP迭代器和生成器用法实例分析
2019/09/28 PHP
php并发加锁问题分析与设计代码实例讲解
2021/02/26 PHP
JavaScript Cookie 直接浏览网站分网址
2009/12/08 Javascript
JS父页面与子页面相互传值方法
2014/03/05 Javascript
javascript中定义类的方法汇总
2014/12/28 Javascript
JavaScript中数据结构与算法(三):链表
2015/06/19 Javascript
js实现滚动条滚动到某个位置便自动定位某个tr
2021/01/20 Javascript
深入理解React中es6创建组件this的方法
2016/08/29 Javascript
JavaScript Base64 作为文件上传的实例代码解析
2017/02/14 Javascript
jQuery实现鼠标经过显示动画边框特效
2017/03/24 jQuery
简单谈谈CommonsChunkPlugin抽取公共模块
2017/12/31 Javascript
js遍历添加栏目类添加css 再点击其它删除css【推荐】
2018/06/12 Javascript
简述vue路由打开一个新的窗口的方法
2018/11/29 Javascript
js实现简单进度条效果
2020/03/25 Javascript
关于element-ui表单中限制输入纯数字的解决方式
2020/09/08 Javascript
python+selenium开发环境搭建图文教程
2017/08/11 Python
Python程序员面试题 你必须提前准备!(答案及解析)
2018/01/23 Python
python如何实现反向迭代
2018/03/20 Python
Python判断对象是否相等及eq函数的讲解
2019/02/25 Python
python 实现12bit灰度图像映射到8bit显示的方法
2019/07/08 Python
代码实例讲解python3的编码问题
2019/07/08 Python
详解python uiautomator2 watcher的使用方法
2019/09/09 Python
Python手绘可视化工具cutecharts使用实例
2019/12/05 Python
开启Django博客的RSS功能的实现方法
2020/02/17 Python
Python datetime模块使用方法小结
2020/06/18 Python
详解python程序中的多任务
2020/09/16 Python
代码中finally中的代码会不会执行
2012/02/06 面试题
文员自我评价怎么写
2013/09/19 职场文书
优秀班干部事迹材料
2014/01/26 职场文书
《小草和大树》教学反思
2014/02/16 职场文书
英文演讲稿开场白
2014/08/25 职场文书
推普周活动总结
2014/08/28 职场文书
初中生思想道德自我评价
2015/03/09 职场文书
原告离婚代理词
2015/05/23 职场文书
详解flex:1什么意思
2022/07/23 HTML / CSS