在python中的数据类型和控制流这篇文章中我们提到过列表,它是基本的数据类型之一。
通俗来说,它就是用来存储一系列数据的。比如存储一个班级的学生。
列表中的每个元素可以通过下标(索引)访问,索引从0开始。
既然列表存储的是一系列值,这必然存在「增删改查」的情况,就像一个班级的学生,有进入学的,也有退学的。
接下来我们来说说,首先我们先从列表的创建开始。
创建列表
list = [ele1 , ele2 , elem3 , ... , elen]
比如,创建一个数字列表或英文字符列表
nums = [1, 2, 3, 4, 5] letters = ["a", "b", "c", "d"];
另外我们也可以创建一个空数组
list = []
访问列表中的值
访问列表中的值,使用下标即可。除了可以访问单个元素外还可以通过切片访问多个元素。
nums = [1, 2, 3, 4, 5] print(nums[1]) #2 print(nums[1:3]) #[2, 3]
添加元素
append() 方法用于向列表的末尾添加元素。会修改原来的列表。
语法:
list.append(ele)
例如:
nums = [1,2] nums.append(3) print(nums) #[1, 2, 3]
插入元素
insert()方法在指定位置插入指定元素。
语法:
list.insert(index, ele)
例如:
list = ['javascript', 'python'] list.insert(0, 'java') print(list) #['java', 'javascript', 'python'] list.insert(1, 'java') print(list) #['javascript', 'java', 'python']
删除元素
想要删除列表中的元素可以有多种方式:
del 语句: 是专门用于执行删除操作,不仅可用于删除列表的元素,也可用于删除变量等。
1、del 语法:删除指定下标的元素
del list[index]
例如:
list = ['java', 'javascript', 'python'] del list[1] print(list) #['java', 'python']
2、pop()方法用于删除指定下标元素,并返回该元素的值。
语法:
list.pop(index)
index 为可选参数,默认为最后一位。
例如:
默认是最后一位
list = ['java', 'javascript', 'python'] list.pop() print(list) #['java', 'javascript']
指定索引
list = ['java', 'javascript', 'python'] list.pop(1) print(list) #['java', 'python']
3、remove()方法用于删除第一次匹配的内容。
语法:
list.remove(ele)
例如:
list = ['java', 'javascript', 'python'] list.remove('java') print(list) #['javascript', 'python']
只会删除第一次匹配的
list = ['java', 'javascript', 'python', 'java'] list.remove('java') print(list) #['javascript', 'python', 'java']
修改列表
通过下标的方式进行修改
list = ['java', 'javascript', 'python'] list[1] = 'js' print(list) #['java', 'js', 'python']
连接与合并
列表可以通过「+」操作符进行拼接
list1 = ['java', 'python'] list2 = ['javascript'] print(list1+list2) #['java', 'python', 'javascript']
extend()方法可用于列表与序列类型的数据合并。会把序列中的元素一次追加到列表的末尾。
语法:
list.extend(seq)
seq:可以为列表,元组,字典,集合。
例如:
合并列表
list1 = ['java'] list2 = ['python'] list1.extend(list2) print(list1) #['java', 'python']
合并元组
list1 = ['java'] list2 = ('javascript', 'python') list1.extend(list2) print(list1) #['java', 'javascript', 'python']
合并字典,合并的却是字典的 key 值。
list1 = ['java'] list2 = { 'web': 'javascript', 'data': 'python' } list1.extend(list2) print(list1) #['java', 'web', 'data']
合并集合
list1 = ['java'] list2 = {'javascript', 'python'} list1.extend(list2) print(list1) #['java', 'javascript', 'python']
查找元素
利用 in 与 not in:判断内容是否在列表中,返回True或Flase
list = ['java', 'javascript', 'python'] print('java' in list) #True print('html' in list) #False print('java' not in list) #False print('html' not in list) #True
index()方法从列表中找出第一个匹配项的索引。如果没找到会抛出异常。
语法:
list.index(ele [, start[, end]])
ele:查找的内容,start:查找的开始位置,end:查找的结束位置。
例如:
list = ['java', 'javascript', 'python'] print(list.index('python')) #2
元组
元组与列表的用法相同,区别就在于元组不可变,而列表是可变的。
tuple = ('java', 'javascript', 'python') tuple[1] = 'js' print(tuple)
此时程序会抛出异常。
tuple = ('java', 'javascript', 'python') del tuple[1] print(tuple)
甚至删除都是不被允许的,一样会抛出异常。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新动态
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]