微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Python中列表和元组的相关语句和方法讲解

列表(list):

首先,列表属于序列,那么序列类型可用如下内建函数――
list(iter):把可迭代对象转换为列表。
str(obj):把obj对象转换为字符串,即用字符串来表示这个对象。
tuple(iter):把一个可迭代对象转换为一个元组
unicode(obj):把对象转换成Unicode字符串。
basestring():抽象工厂函数,其作用仅仅是为str和unicode函数提供父类,所以不能被实例化,也不能被调用
enumerate(iter):接受一个可迭代对象作为参数,返回一个enumerate对象,该对象生成由iter每个元素的index值和item值组成的元组
len(seq):返回seq的长度。
max(iter,key=None)、max(arg0,arg1...,key=None):返回iter或(arg0,arg1...)的最大值,如果指定了key,这个key必须是一个可以传给sort()方法的,用于比较的回调函数
min(iter,key=None)、min(arg0,arg1...)的最小值,如果指定了key,这个key必须是一个可以传给sort()方法的,用于比较的回调函数
reversed(seq):接受一个序列作为参数,返回一个以逆序访问的迭代器。
sorted(iter,cmp=None,key=None,reverse=False):接受一个可迭代对象作为参数,返回一个有序的列表,可选参数cmp、key和reverse和list.sort()内建函数含义一样。
sum(seq,init=0):返回seq和可选参数init的总和,其效果等同于reduce(operator.add,seq,init)。
zip([it0,it1...]):返回一个列表,其第一个元素是it0、it1...这些元素的第一个元素组成的一个元组,其它元素依次类推。

列表就像一个线性容器,但是比C++的 lis t扩展多得多
列表里的元素可以是相同类型,也可以包含各种类型,比如列表里嵌套另一个列表

列表示例:

>>> L1 = [1,2,3] 
>>> type(L1) 
<class 'list'> 
>>> L1 = [1,'a',1.4] 
>>> L1 
[1,1.4] 
>>> L1 = [ ['sub'],1,'n'] 
>>> L1 
[['sub'],'n'] 

list的索引是也是从0开始,但也可以从后访问,L1[-1] 表示L1中的最后一个元素

>>> L1 
[['sub'],'n'] 
>>> L1[0] 
['sub'] 
>>> L1[-1] 
'n' 

对列表可以进行切片,切片的操作类似于对函数调用,返回值一个新的列表
切片 L1[ x : y : z ] 是半开闭区间(z通常不用写),如L1[1:3] 返回的是一个从 L1[1] 开始到 L1[2] 结束的列表,不包含L1[3]
x 不写表示从头开始,y 不写表示直到列表结束,z 用于表示步长, 认是1, 可以认为是在这个区间里每 z 个元素取一个(取第一个),可以是负数,表示从后到前遍历

>>> L1 = [1,3,4,5,6] 
>>> L1[1:3] 
[2,3] 
>>> L1[:3] 
[1,3] 
>>> L1[1:] 
[2,6] 
>>> L1[-3:-1] 
[4,5] 
>>> L2 = L1[:] 
>>> L2 
[1,6] 
>>> L1[::2] 
[1,5] 
>>> L1[::-1] 
[6,1] 

 

列表可以做加法,做乘法,字符串也可以看做一个字符的列表

>>> L1 = [1,2] 
>>> L2 = [3,4] 
>>> L1 + L2 
[1,4] 
>>> 5 * L1 
[1,2] 

in语句,判断一个对象是否在一个字符串/列表/元组
not 语句表示对后面的否定
len  可以检测字符串/列表/元祖/字典的元素个数
max 可以返回最大元素,min 返回最小元素

>>> L1 
[1,2] 
>>> 3 in L1 
True 
>>> 5 in L1 
False 
>>> 3 not in L1 
False 
>>> 5 not in L1 
True 
>>> len(L1) 
5 
>>> max(L1) 
4 
>>> min(L1) 
1 

操作:

>>> #赋值 
>>> L1[1] = 5 
>>> L1 
[1,2] 
>>> #删除 
>>> del L1[1] 
>>> L1 
[1,2] 
>>> #分片赋值 
>>> L1[2:] = [6,7,8] 
>>> L1 
[1,6,8] 
>>> L1[1:3] = [] 
>>> L1 
[1,8] 

list 的函数
append( x ) 是将 x 作为一个元素添加到列表的末尾,即使 x 是一个列表

>>> L1 
[1,8] 
>>> L1.append(3) 
>>> L1 
[1,8,3] 
>>> L1.append([4,5]) 
>>> L1 
[1,[4,5]] 
>>> 4 in L1 
False 


count( x) 统计 x 在列表中出现的次数

>>> L1 = [1,8] 
>>> L1.count(2) 
1 
>>> L1.count(3) 
0 


extend( x ) 将x 作为一个列表与原列表合并,添加到末尾。若不是列表,则编译器尝试将 x 转换为列表然后执行操作,不成功就会报错

>>> L1 
[1,8] 
>>> L1.extend([4,5] 
>>> 4 in L1 
True 


index ( x ) 返回 x 在列表中的坐标,若 x 不在列表中会出错

>>> L1.index(2) 
1 

insert( i,x) 在位置i 插入元素x

>>> L1 
[1,5] 
>>> L1.insert(0,'a') 
>>> L1 
['a',5] 
>>> L1.insert(-1,'b') 
>>> L1 
['a','b',5] 

pop( i ) 删除位置 i 的元素并将它返回,认可以不写 i ,删除最后一个元素,不存在会出错

>>> L1 = [1,8] 
>>> L1.pop(1) 
2 
>>> L1 
[1,8] 
>>> L1.pop() 
8 
>>> L1 
[1,7] 

remove( x ) 移除在 列表中 x 的第一个匹配项,x 不存在会出错

>>> L1.remove(2) 
>>> L1 
[1,8] 


reverse() 将列表逆序

>>> L1 = [1,8] 
>>> L1.reverse() 
>>> L1 
[8,1] 


sort 将原列表排序,返回None,有两个可选参数,key 和 reverse,认为升序排列

>>> L1 
[8,1] 
>>> L1.sort() 
>>> L1 
[1,8] 
>>> L1.sort(reverse = True) 
>>> L1 
[8,1] 


>>> L1 = ['a','ccc','abcd','bc','cd','abc'] 
>>> L1.sort(key = len) 
>>> L1 
['a','abc','abcd'] 

元组(tuple)
元组也属于序列,但元组为不可修改的列表。所以元组没有以上序列通用方法可用!
一个元素的元组表示为 ( 1,)

>>> x = (1,) 
>>> type(x) 
<class 'tuple'> 
>>> x = (1) 
>>> type(x) 
<class 'int'> 

元组可转换成列表,反之亦然。
内建的 tuple() 函数接受一个列表参数,并返回一个包含同样元素的元组,而 list() 函数接受一个元组参数并返回一个列表。
效果上看, tuple() 冻结列表,而 list() 融化元组

>>> x = [1,1] 
>>> y = (1,1) 
>>> type(x) 
<class 'list'> 
>>> type(y) 
<class 'tuple'> 
>>> z = tuple(x) 
>>> z 
(1,1) 
>>> z = list(y) 
>>> z 
[1,1] 

可以用列表 或 元组 进行一次多赋值:

>>> L1 = (1,4) 
>>> (x,y,z) = L1 
>>> x 
1 
>>> y 
2 
>>> z 
4 

>>> L1 = [1,4] 
>>> (x,z) = L1 
>>> x 
1 
>>> y 
2 
>>> z 
4 


[] ,和 () 在布尔值中表示 False

 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


我最近重新拾起了计算机视觉,借助Python的opencv还有face_recognition库写了个简单的图像识别demo,额外定制了一些内容,原本想打包成exe然后发给朋友,不过在这当中遇到了许多小问题,都解决了,记录一下踩过的坑。 1、Pyinstaller打包过程当中出现warning,跟d
说到Pooling,相信学习过CNN的朋友们都不会感到陌生。Pooling在中文当中的意思是“池化”,在神经网络当中非常常见,通常用的比较多的一种是Max Pooling,具体操作如下图: 结合图像理解,相信你也会大概明白其中的本意。不过Pooling并不是只可以选取2x2的窗口大小,即便是3x3,
记得大一学Python的时候,有一个题目是判断一个数是否是复数。当时觉得比较复杂不好写,就琢磨了一个偷懒的好办法,用异常处理的手段便可以大大程度帮助你简短代码(偷懒)。以下是判断整数和复数的两段小代码: 相信看到这里,你也有所顿悟,能拓展出更多有意思的方法~
文章目录 3 直方图Histogramplot1. 基本直方图的绘制 Basic histogram2. 数据分布与密度信息显示 Control rug and density on seaborn histogram3. 带箱形图的直方图 Histogram with a boxplot on t
文章目录 5 小提琴图Violinplot1. 基础小提琴图绘制 Basic violinplot2. 小提琴图样式自定义 Custom seaborn violinplot3. 小提琴图颜色自定义 Control color of seaborn violinplot4. 分组小提琴图 Group
文章目录 4 核密度图Densityplot1. 基础核密度图绘制 Basic density plot2. 核密度图的区间控制 Control bandwidth of density plot3. 多个变量的核密度图绘制 Density plot of several variables4. 边
首先 import tensorflow as tf tf.argmax(tenso,n)函数会返回tensor中参数指定的维度中的最大值的索引或者向量。当tensor为矩阵返回向量,tensor为向量返回索引号。其中n表示具体参数的维度。 以实际例子为说明: import tensorflow a
seaborn学习笔记章节 seaborn是一个基于matplotlib的Python数据可视化库。seaborn是matplotlib的高级封装,可以绘制有吸引力且信息丰富的统计图形。相对于matplotlib,seaborn语法更简洁,两者关系类似于numpy和pandas之间的关系,seabo
Python ConfigParser教程显示了如何使用ConfigParser在Python中使用配置文件。 文章目录 1 介绍1.1 Python ConfigParser读取文件1.2 Python ConfigParser中的节1.3 Python ConfigParser从字符串中读取数据
1. 处理Excel 电子表格笔记(第12章)(代码下载) 本文主要介绍openpyxl 的2.5.12版处理excel电子表格,原书是2.1.4 版,OpenPyXL 团队会经常发布新版本。不过不用担心,新版本应该在相当长的时间内向后兼容。如果你有新版本,想看看它提供了什么新功能,可以查看Open