列表
序列是 Python 中最基本的数据结构。
序列中的每个值都有对应的位置值,称之为索引,第一个索引是 0,第二个索引是 1,依此类推。
Python 有 6 个序列的内置类型,但最常见的是列表和元组。
列表都可以进行的操作包括索引,切片,加,乘,检查成员。
此外,Python 已经内置确定序列的长度以及确定最大和最小的元素的方法。
列表是最常用的 Python 数据类型,它可以作为一个方括号内的逗号分隔值出现。
列表的数据项不需要具有相同的类型,可以存放任意类型的数据
创建列表
list1 = ['Google', 'Runoob', 1997, 2000] list2 = [1, 2, 3, 4, 5 ] list3 = ["a", "b", "c", "d"] list4 = ['red', 'green', 'blue', 'yellow', 'white', 'black']
list5 = [11, 11.23, True, '23232', ['11', '22']]
列表索引
正向索引(索引值从0,1,2......,n-1(n为列表数据的数量))
list2 = [11, 11.23, True, '23232', ['11', '22'],(5,6)] print(list2[0]) #list2[0]表示取列表的第一个,即list2[0]=11;list2[1]=11.23;....依次类推 print(list2[1]) print(list2[2]) print(list2[3])
反向索引(索引值从-1,-2,-3......,n)
list2 = [11, 11.23, True, '23232', ['11', '22'],(5,6)] print(list2[-1]) #list2[-1]表示取列表最后一个,即list2[-1]=(5,6);list2[-2]=['11','22'];....依次类推 print(list2[-2]) print(list2[-3]) print(list2[-4])
使用索引截取列表(切片)
【start:end】
start:起始索引
end:结尾索引(不包含)
list = [11, 11.23, True, '23232', ['11', '22'],(5,6)] print(list[0:2]) #list[0:2]表示取出list[0]、list[1]的值,不包括list[2] print(list[1:-1]) #表示从list[1]=11.23开始,到list[-1]=(5,6)结束(但不包括list[-1],实际是到list[-2]=['11','22']结束) print(list[:]) #list[:]不填默认从头取到尾,相当于list[0:len(list)]其中len(list)=6 print(list[1:]) #list[1:]表示从下标[1]取到尾 print(list[:3]) #表示从头(list[0])取到3(不包括list[3]) print(list[-1:-3]) #反向取结果会输出为空 print(list[3:1])
结论:
list[start,end]表示:从头下标开始(包含)截取到尾下标(不包含)
切片补充:
【start:end:step】
start:起始索引,从0开始,-1表示结束
end:结束索引
step:步长,end-start,步长为正时,从左向右取值。步长为负时,反向取值
a = [1,2,3,4,5,6,7] print(a[1:5:2]) #从a[1]开始到a[5](不包括a[5]);步长为2,即取a[1]、a[3],即【2,4】 print(a[::-1]) #a[::-1]即a[-1:-len(a)-1:-1];len(a)为7即长度;则可看成a[-1:-8:-1];则从a[-1]=7开始,到a[-8](不包含)即到a[-7]=1;步长为-1,则结果倒序[7,6,5,4,3,2,1] print(a[1::-1]) #a[1::-1]即a[1:-8:-1];从a[1]=2开始,到a[-8](不包含)即到a[-7]=1;所以结果输出[2,1] print(a[:2:-1]) #a[:2:-1]即a[-1:2:-1];从a[-1]=7开始,到a[2](不包含),即到a[3]=4;则结果为[7,6,5,4]
说明:
b = a[i:j] # 表示复制a[i]到a[j-1],以生成新的list对象 a = [0,1,2,3,4,5,6,7,8,9] b = a[1:3] # [1,2] # 当i缺省时,默认为0,即 a[:3]相当于 a[0:3] # 当j缺省时,默认为len(alist), 即a[1:]相当于a[1:10] # 当i,j都缺省时,a[:]就相当于完整复制一份a b = a[i:j:s] # 表示:i,j与上面的一样,但s表示步进,缺省为1. # 所以a[i:j:1]相当于a[i:j] # 当s<0时,i缺省时,默认为-1. j缺省时,默认为-len(a)-1 # 所以a[::-1]相当于 a[-1:-len(a)-1:-1],也就是从最后一个元素到第一个元素复制一遍,即倒序。
列表增删查改
append()方法:用于在列表末尾添加一个元素
li = [11, 22, 33, 44] li.append(99) li.append(999) print(li)
extend()方法:往列表尾部一次性添加多个元素
可以添加列表、元组、集合、字典,若为字典,则仅会将键(key)作为元素依次添加至原列表的末尾
li = [11, 22, 33, 44] li.extend([888, 999, 777]) li.extend('abc') print(li)
insert()方法:用于将指定对象插入列表的指定位置
li = [11, 22, 33, 44] li.insert(2, 'musen')#表示在位置【2】插入一个'musen'字符串 print(li)
拓展:insert 和 append 函数;当增加的是列表中的一个元素(子列表),则新增的元素初始只作为原元素的一个镜像,这时候如果修改原元素(子列表)中的一个子元素,则新增元素同样变化,修改新元素中的子元素也是如此
a=[[0,1],[1,2],[2,3]] #其中a[0]=[0,1];a[1]=[1,2];a[2]=[2,3];属于嵌套列表 a.insert(2,a[1]) #在位置2插入一个a[1];得到a=[a[0],a[1],a[2],a[3]];说白了就是把自己的子列表插了进去,相当于搞了个镜像 a.append(a[3]) #在末尾加了一个a[3];得到a=[a[0],a[1],a[2],a[3],a[4]];同上 print (a) #此时a=[[0, 1], [1, 2], [1, 2], [2, 3], [2, 3]] a[1][1]=0 #a[1][1]=0实际就是把a=[[0,1],[1,2],[1,2],[2,3],[2,3]];标记的2改为了0 a[4][1]=4 #同上 print(a) #a=[[0, 1], [1, 0], [1, 0], [2, 4], [2, 4]];结果之前插入和添加的“镜像”也发生了改变
如果想只修改其中一个元素(子列表),必须把该子列表完整定义一遍
a=[[0,1],[1,2],[2,3]] a.insert(2,a[1]) a.append(a[3]) print (a) a[1][1]=0 a[4][1]=4 print(a) a[1]=[1,1] #完整定义 print(a)
用id()查看下内存地址
a=[[0,1],[1,2],[2,3]] a.insert(2,a[1]) print(id(a[1])==id(a[2])) #Ture,说明a[1]、a[2]的存放地址(内存地址)都是同一个,所以后面修改其中一个的内容,另一个也会跟着变 print(a) a.append(a[3]) print(id(a[3])==id(a[4])) #Tuer print (a) a[1][1]=0 print(id(a[1])==id(a[2])) #Ture a[4][1]=4 print(id(a[3])==id(a[4])) #Ture print(a) a[1]=[1,1] print(id(a[1])==id(a[2])) #false,重新完整定义后,实质是相当于重新添加了一个对象,地址就改变了 print(a)
remove()方法:指定元素进行删除
li = [11, 22, 33, 44, 55, 66, 77, 88, 99,11,22,33,11,22] li.remove(11) #列表有多个11元素,删除时只删除第一个匹配对象(最靠前的那个) print(li)
pop()方法:指定索引进行删除(默认删除最后一个)
li = [11, 22, 33, 44, 55, 66, 77, 88, 99,11,22,33,11,22] res = li.pop(0)#pop方法执行后,会返回删除的数据 print("删除的元素是:",res) print(li)
clear()方法:清空列表所有元素(调用完会返回删除的数据)
li = [11, 22, 33, 44, 55, 66, 77, 88, 99,11,22,33,11,22] li.clear() print(li)
修改列表元素:直接可通过索引值进行修改
li = [11, 22, 33, 44, 55] li[2] = 333 print(li)
查找元素:
li = [11, 22, 33, 44, 55,11,22,11,11,11] # 方式1:索引取值 res = li[3] print(res) # index:查找元素对应的索引,只会找到第一个 res = li.index(22) print(res) # count:统计某个元素的个数 res = li.count(55) print(res)
python表达式 结果 说明
len([1, 2, 3]) 3 长度
[1, 2, 3] + [4, 5, 6] [1, 2, 3, 4, 5, 6] 组合
['Hi!'] * 4 ['Hi!', 'Hi!', 'Hi!', 'Hi!'] 重复
3 in [1, 2, 3] True 元素是否存在于列表中
for x in [1, 2, 3]: print(x, end=" ") 1 2 3 迭代
列表拼接
li1 = [1,2,3] li1 += [4,5,6] print(li1)
python列表的函数:
len(list)
列表元素个数
max(list)
返回列表元素最大值
min(list)
返回列表元素最小值
list(seq)
将元组转换为列表
python列表的方法:
list.append(obj)
在列表末尾添加新的对象
list.count(obj)
统计某个元素在列表中出现的次数
list.extend(seq)
在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表)
list.index(obj)
从列表中找出某个值第一个匹配项的索引位置
list.insert(index, obj)
将对象插入列表
list.pop([index=-1])
移除列表中的一个元素(默认最后一个元素),并且返回该元素的值
list.remove(obj)
移除列表中某个值的第一个匹配项
list.reverse()
反向列表中元素
list.sort( key=None, reverse=False)
对原列表进行排序
升序(从小到大):li2.sort()
降序(从大到小):li2.sort(reverse=True)
列表倒序li2.reverse()
list.clear()
清空列表
list.copy()
复制列表
补充:
append() 属于是浅拷贝
alist = [] num = [2] alist.append( num ) print(id( num ) == id( alist[0] )) #从输出结果为ture可知,拷贝后,num和alist[0]的地址是一样的,此时若改变其中一个的值,另一个也会随之改变
需要使用深拷贝方法
import copy alist = [] num = [2] alist.append(copy.deepcopy( num ) ) print(id( num ) == id( alist[0] ))
拓展:
[表达式 for 变量 in 列表]
或者
[表达式 for 变量 in 列表 if 条件]
list1 = [1,2,3,4,5,6,7] list2 = [8,9,10,11,12,13,14] print([x**2 for x in list1]) print([i for i in range(5)]) print([[i for i in range(5)] for i in range(5)]) print ([x**2 for x in list1 if x>5]) print (dict([(x,x*10) for x in list1])) print ([ (x, y) for x in range(10) if x % 2 if x > 3 for y in range(10) if y > 7 if y != 8 ]) sq=[list1[i]+list2[i] for i in range(len(list1))] print(sq) print ([x*y for x in [1,2,3] for y in [1,2,3]]) testList = [1,2,3,4] def mul2(x): return x*2 print ([mul2(i) for i in testList])