【Python基础教程第2版】——第二讲:列表和元组
引言:
什么是数据结构?
数据结果是通过某种方式(例如对元素进行编号)组织在一起的数据元素的集合。Python中最常用的数据结构是序列。
Python包含6种内建的序列:列表和元组(最常用:列表可以修改、元组则不能)、字符串、Unicode字符串、buffer对象和xrange对象。
一、序列的通用操作:
1、索引(从左到右以0开始不断递增;从右到做-1开始不断递减)
>>> greeting = 'hello'
>>> greeting[0]
'h'
>>> greeting[-1]
'o'
2、分片(开始元素为冒号前的,结束元素为冒号后的元素的前一个)
>>> greeting[0:3](0,1,2)
'hel'
>>> greeting[-3:-1](-3,-2)
'll'
>>> greeting[-3:](-3,到最后)
'llo'
>>> greeting[:]
'hello'
>>> greeting[1:3:2] #以2为步长,前面的都是默认以1为步长
'e'
3、序列相加(只有相同类型的才可以相加)
>>> [1,2,3]+[4,5,6]
[1, 2, 3, 4, 5, 6]
>>> 'hello'+'world'
'helloworld'
>>> [1,2,3]+'world'
Traceback (most recent call last):
File "<pyshell#10>", line 1, in <module>
[1,2,3]+'world'
TypeError: can only concatenate list (not "str") to list
4、乘法
>>> 'python'*5
'pythonpythonpythonpythonpython'
>>> [56]*4
[56, 56, 56, 56]
>>> sequence = [None]*10 #空列表[None]
>>> sequence
[None, None, None, None, None, None, None, None, None, None]
5、成员资格(使用in运算符检查一个值是否在序列中)
>>> ll = '8uusdf'
>>> 'u' in ll
True
>>> 'we'in ll
False
>>> 'uus' in ll
True
>>> 'us' in ll
True
>>> 'ud' in ll
False
6、长度、最小值和最大值(len(序列名称)用的很多)
>>> numbers = [89, 56, 100]
>>> len(numbers)
3
>>> max(numbers)
100
>>> min(numbers)
56
二、列表:Python的“苦力”(这里讲列表的有用的专属的方法)
(一)基本操作
1、list方法(list方法将字符串转化成列表形式;join可以将列表通过某个符号连起来,如通过''空字符将字符列表连起来就是一个字符串)
>>> list1 = list('hello')
>>> list1
['h', 'e', 'l', 'l', 'o']
>>> ''.join(list1)
'hello'
>>>
2、元素赋值
>>> x = [1,2,3]
>>> x[1] = 6
>>> x
[1, 6, 3]
3、删除元素
>>> del x[1]
>>> x
[1, 3]
3、分片赋值
>>> name = list('i love you')
>>> name
['i', ' ', 'l', 'o', 'v', 'e', ' ', 'y', 'o', 'u']
>>> name[2:6] = list('hate')
>>> name
['i', ' ', 'h', 'a', 't', 'e', ' ', 'y', 'o', 'u']
>>> ''.join(name)
'i hate you'
以下为不替换任何元素情况下插入元素:
>>> numbers = [1,5]
>>> numbers[1:1] = [2,3,4]
>>> numbers
[1, 2, 3, 4, 5]
以下为不替换任何元素情况下删除元素:
>>> numbers
[1, 2, 3, 4, 5]
>>> numbers[1:5] = []
>>> numbers
[1]
(二)列表方法——很重要(注意定义变量或者对象的名称,不要与内建函数或者某些类的方法同名,否则会导致调用失败)
1、append——在列表末尾追加新的对象(会改变原列表)
>>> lst = [1,2,3]
>>> lst.append(4)
>>> lst
[1, 2, 3, 4]
2、count——统计某元素在列表中出现的次数
>>> x = [[1,2],2,3,[1,2],1,1]
>>> x.count(1)
2
>>> x.count([1,2])
2
3、extend——一次性在末尾追加多个值(会改变原列表)
>>> a = [1,2,3]
>>> b = [4,5,6]
>>> a.extend(b)
>>> a
[1, 2, 3, 4, 5, 6]
若使用+操作,则不会改变原列表的值:
>>> a = [1,2,3]
>>> b = [4,5,6]
>>> a+b #生成新的列表
[1, 2, 3, 4, 5, 6]
>>> a
[1, 2, 3]
4、index——从列表中找出某个值第一个匹配项的索引位置
>>> kk = ['what', 'is', 'your', 'name', '?']
>>> kk.index('is')
1
>>> kk2 = ['what', 'is', 'll', 'is', 'doudou']
>>> kk2.index('is') #注:列表中有两个'is',index会从左往右找,找到就直接返回,即找到第一个就停止,如果没有的话,就会返回错误
1
>>> kk2.index('wer')
Traceback (most recent call last):
File "<pyshell#16>", line 1, in <module>
kk2.index('wer')
ValueError: 'wer' is not in list
5、insert——将对象插入到列表中(参数为<插入位置,对象的值>,插入位置从0开始计算,想要在哪里插入,就直接写上该位置的索引值即可)
>>> numbers = [1,2,3,5,6,7]
>>> numbers.insert(3, 'four')
>>> numbers
[1, 2, 3, 'four', 5, 6, 7]
6、pop——移除列表中的一个元素,默认是最后一个
注:pop方法是唯一一个既能修改列表又返回元素值(除了None)的列表方法
>>> x = [1,2,3]
>>> x.pop()
3
>>> x
[1, 2]
>>> x.pop(0) #默认是最后一个,这里可以指定参数,为index索引值
1
>>> x
[2]
7、remove——移除列表中某个值的第一个匹配项(根据值,而不是index索引值)【与pop相反,没有返回值的原位置修改的方法】
>>> x = ['to', 'be', 'or', 'not', 'to', 'be']
>>> x.remove('be')
>>> x
['to', 'or', 'not', 'to', 'be']
>>> x.remove('be')
>>> x
['to', 'or', 'not', 'to']
>>> x.remove('234')
Traceback (most recent call last):
File "<pyshell#11>", line 1, in <module>
x.remove('234')
ValueError: list.remove(x): x not in list
8、reverse——反向存放列表中的元素(改变列表而不返回值)
>>> x = [1,2,3]
>>> x.reverse()
>>> x
[3, 2, 1]
9、sort——排序方法:在原位置对列表进行排序
>>> x = [3,5,2,7,1,10,6]
>>> x.sort()
>>> x
[1, 2, 3, 5, 6, 7, 10]
若需要保留X的值,则可以先把X的副本赋给Y,然后对Y进行排序
>>> x = [3,5,2,7,1,10,6]
>>> y = x[:] #注,一定是通过这种方式赋值,不能直接y = x
>>> y.sort()
>>> y
[1, 2, 3, 5, 6, 7, 10]
>>> x
[3, 5, 2, 7, 1, 10, 6]
下面是直接y = x的情况:
>>> x = [3,5,2,7,1,10,6]
>>> y = x
>>> y.sort()
>>> y
[1, 2, 3, 5, 6, 7, 10]
>>> x
[1, 2, 3, 5, 6, 7, 10] #这里的y和x指向的是同一个列表了
也可以通过sorted()函数,代码如下:
>>> x = [3,5,2,7,1,10,6]
>>> y = sorted(x)
>>> y
[1, 2, 3, 5, 6, 7, 10]
>>> x
[3, 5, 2, 7, 1, 10, 6]
10、cmp——比较大小,cmp(x,y)中,x大于y会返回1;x小于y返回0
>>> cmp(42,32)
1
>>> cmp(99,100)
-1
>>> numbers = [5,2,9,7]
>>> numbers.sort(cmp)
>>> numbers
[2, 5, 7, 9]
三、元组
1、元组的定义:
>>> 1,2,3
(1, 2, 3)
>>> 42,
(42,)
>>> ()
()
>>> 3*(40+2)
126
>>> 3*(40+2,)
(42, 42, 42)
2、tuple()函数 ——与列表的list方法类似,可以通过该函数将列表或者字符串转化成元组形式
>>> tuple([1,2,3])
(1, 2, 3)
>>> tuple('abc')
('a', 'b', 'c')
>>> tuple((1,2,3))
(1, 2, 3)
3、元组的基本操作——与列表不同,没有列表的一堆方法,元组的基本操作(创建元组和访问元组元素)可参见其他类型的序列
>>> x = 1,2,3
>>> x[1]
2
>>> x[0:2]
(1, 2)
【Python基础教程第2版】——第二讲:列表和元组的更多相关文章
- Python基础教程学习笔记:第二章 列表和元组
1.序列中元素的索引: 第一个元素索引是0,第二个是1,依次递增 最后一个元素索引是-1,倒数第二个是-2,依次递减 2.序列(Sequence)的种类: 列表(list).元组(tuple).字符串 ...
- Python基础教程笔记——第2章:列表和元组
python shell 里重复上一次的命令:Alt+p 2.3 列表:Python的苦力 (1)list函数 (2)列表赋值,不蹦蹦为一个元素不存在的位置赋值 (3)删除元素,del name[1] ...
- Python基础教程-第3版(文字版) 超清文字-非扫描版 [免积分、免登录]
此处免费下载,无需账号,无需登录,无需积分.收集自互联网,侵权通知删除. 点击下载:Python基础教程-第3版 备用下载:Python基础教程-第3版
- Python基础教程(第2版 修订版) pdf
Python基础教程(第2版 修订版) 目录 D11章快速改造:基础知识11.1安装Python11.1.1Windows11.1.2Linux和UNIX31.1.3苹果机(Macintosh)41. ...
- python基础知识3——基本的数据类型2——列表,元组,字典,集合
磨人的小妖精们啊!终于可以归置下自己的大脑啦,在这里我要把--整型,长整型,浮点型,字符串,列表,元组,字典,集合,这几个知识点特别多的东西,统一的捯饬捯饬,不然一直脑袋里面乱乱的. 一.列表 1.列 ...
- Python基础学习参考(六):列表和元组
一.列表 列表是一个容器,里面可以放置一组数据,并且列表中的每个元素都具有位置索引.列表中的每个元素是可以改变的,对列表操作都会影响原来的列表.列表的定义通过"[ ]"来定义,元素 ...
- 【Python基础教程第2版】——第一讲:基础知识
1.长字符串:(用三引号如'''或者"""来引起来) >>> print """This is a very log st ...
- Python基础教程(第3版) 笔记(二)
1.8模块Python提供了完成(某人的年 龄为32.9,并想将这个值向下圆整为32,因为他还没有满33岁)这种任务的函 数floor.导入模块,可以使用特殊命令import.函数floor包含在模块 ...
- Python基础教程(第3版) 笔记(三)
1.9.1让脚本像普通程序一样在UNIX中运行脚本,只需将下面的代码作为脚本的第一行, 就可在UNIX中轻松运行脚本: #!/usr/bin/env python 要像普通程序一样运行脚本,还必须将其 ...
随机推荐
- cookie js案例
//存cokie function setcookie(keys,value,time){ document.cookie=keys+"="+decodeURIComponent( ...
- scrapy 抓取拉勾网数据
其实很简单,却因为一些小问题,折腾不少时间,简要记录一下,以备后需. >> scrapy startproject lagou >> cd lagou >> scr ...
- tp5模型笔记---多对多
关联模型 一对一:HAS_ONE 以及对应的BELONEGS_TO 一对多:HAS_MANY 以及相对的BELONGS_TO 多对多:BELONGS_TO_MANY 步骤: 第一:创建Users模型 ...
- 第12章 网络基础(1)_网络分层和TCP/IP协议族
1. 协议的概念 (1)计算机网络中实现通信必须有一些约定.如对速率.传输代码.代码结构.传输控制步骤和出错控制等约定,这些约定即被称为通信协议 (2)在两个节点之间要成功地进行通信,两个节点之间必须 ...
- 第2课 C 到 C++ 的升级
1. C与C++的关系 (1)C++继承了所有的C特性,并在C的基础上提供了更多的语法和特性. (2)C++的设计目标是运行效率与开发效率的统一,它更强调的是语言的实用性. 2. C到C++ 的升级 ...
- 基于RDBMS的OLAP的解决方案
BI项目如何开发: 了解OLAP的分析方法: 对数据进行多维建模分析,也就是自己设计自己的数据方体,之后程序自动生成数据方体 数据方体: 1.自动成的表结构,仅仅有你需要的列 2.生成一条SQL语句( ...
- windows2008r2共享文件夹设置方法
一,无法启用网络发现的方法 参考网站: http://www.jb51.net/os/windows/win2008/154631.html Function Discovery R ...
- 将文本转换为json的工具类
JSONObject jsonObj = JSONObject.fromObject("文本"); 参考:https://www.cnblogs.com/joahyau/p/ ...
- 7.分工合作include:指定多个配置文件
转自:https://wenku.baidu.com/view/84fa86ae360cba1aa911da02.html 比如让jack来单独开发一个action,在jack.xml中的配置文件为: ...
- Putty全屏/退出全屏快捷键