list列表简介:列表是python的基础数据类型之⼀ ,其他编程语⾔也有类似的数据类型. 比如JS中的数
组, java中的数组等等. 它是以[ ]括起来, 每个元素⽤' , '隔开⽽且可以存放各种数据类型:。
lst = [1, 'GG', "MM", [1,666,0,"嘻嘻"]
tuple元组简介:俗称不可变的列表.⼜被成为只读列表, 元组也是python的基本数据类型之⼀, ⽤⼩括
号括起来, ⾥⾯可以放任何数据类型的数据, 查询可以. 循环也可以. 切片也可以. 但就是不能改.
tu = ("x=1","y=2")
一、列表的索引的切片
列表的索引和切片与字符串的索引切片一样:list[索引号 ]
lst = ["麻花藤", "王剑林", "⻢芸", "周鸿医", "向华强"]
print(lst[0]) # 获取第⼀个元素
列表的切片
lst = ["华仔", '赫本', '赵四', "孙艺珍", '车太贤']
print(lst[3][1]) # 索引拿到的是元素
print(lst[-3])
二、列表的增
1、list.append("元素") 表示在列表后面新增一个元素,添加到末尾------------------追加
lst = ["西红柿首富","无双", "影", "超能泰坦"]
lst.append("楚留香传奇") # 可变的数据类型 没有返回值
print(lst)#['西红柿首富', '无双', '影', '超能泰坦', '楚留香传奇']
2、list.insert(索引号,”元素“) 表示在索引号的位置插入一个元素------------------插入
lst = ["西红柿首富","无双", "影", "超能泰坦"]
lst.insert(1, "建国大业") # 插入, 效率不高. 索引的变更
print(lst)#['西红柿首富', '建国大业', '无双', '影', '超能泰坦']
3、list.extend("可迭代对象") 表示在在末尾一一添加可迭代对象的每一个元素------------------迭代添加
lst = ["西红柿首富","无双", "影", "超能泰坦"]
lst.extend("周杰伦")
print(lst) #['西红柿首富', '无双', '影', '超能泰坦', '周', '杰', '伦']
lst.extend(["倚天屠龙记", "乡村爱情"])
print(lst) #['西红柿首富', '无双', '影', '超能泰坦', '周', '杰', '伦', '倚天屠龙记', '乡村爱情']
二、列表的删除
1、list.pop() 表示弹出一个元素,不添加索引,默认表示弹出最后一个,返回需要删除的元素
lst=[1,2,3,4,5]
lst.pop()#弹出最后一个元素
print(lst) #[1, 2, 3, 4]
2、list.pop(索引号) 表示根据索引号弹出元素,返回需要删除的元素
lst=[1,2,3,4,5]
lst.pop(2) #弹出索引号为2的元素
print(lst) #[1, 2, 4, 5]
3、list.remove("元素") 表示指定元素删除
lst=["张三丰","张翠山","张无忌","赵敏"]
lst.remove("赵敏")
print(lst) #['张三丰', '张翠山', '张无忌']
4、del lst[索引] 按照索引删除元素
lst = ["杰森斯坦森", "勒布朗詹姆斯", "尼古拉斯凯奇", "郭达森"]
del lst[2] # 类似pop
print(lst) #['杰森斯坦森', '勒布朗詹姆斯', '郭达森']
del lst[start:end ] 切片式删除
lst = ["杰森斯坦森", "勒布朗詹姆斯", "尼古拉斯凯奇", "郭达森"]
del lst[2:] # 批量删除 ['杰森斯坦森', '勒布朗詹姆斯']
del lst[strat:end:step] 间隔切片删除
lst = ["杰森斯坦森", "勒布朗詹姆斯", "尼古拉斯凯奇", "郭达森"]
del lst[1:5:2] # 切片删除
print(lst) #['杰森斯坦森', '尼古拉斯凯奇']
5、lst.clear() 表示清空列表
lst = ["杰森斯坦森", "勒布朗詹姆斯", "尼古拉斯凯奇", "郭达森"]
lst.clear() # 清空列表
print(lst) #[]
三、列表的修改
list[索引]=new_value 表示修改制定索引位置的值
lst = ["太⽩", "太⿊", "五⾊", "银王", "⽇天"]
lst[1] = "太污" # 把1号元素修改成太污
print(lst)#['周杰伦', '周星星', '周星驰', '周润发']
lst[1:5:3] = ["麻花藤", "哇靠"] # 切⽚修改也OK. 如果步⻓不是1, 要注意. 元素的个数
print(lst) #['太⽩', '麻花藤', '五⾊', '银王', '哇靠'] lst[1]='麻花藤',lst[4]="哇靠"
lst[1:4] = ["李嘉诚个⻳⼉⼦"] # 如果切⽚没有步⻓或者步⻓是1. 则不⽤关⼼个数
print(lst)#['太⽩', '李嘉诚个⻳⼉⼦', '哇靠']
四、查询
for el in list;
print(el)
lst = ["胡辣汤", "猪脚饭", "吱吱冒油的猪蹄子", "猪头肉"]
for food in lst: # 列表可以使用for循环。 list是一个可迭代对象
print(food) #food表示列表中的每一项
五、列表的补充知识--排序
1、list.sort( ) 表示升序排序
2、lst.reverse( ) #列表反过来
lst=[77,88,55,66,99,33,11,22,44]
lst.sort() #升序排序
print(lst) #[11, 22, 33, 44, 55, 66, 77, 88, 99]
lst.reverse() #反转
print(lst) #[99, 88, 77, 66, 55, 44, 33, 22, 11]
2、list.sort(reverse=True) #倒序。从大到小
lst=[77,88,55,66,99,33,11,22,44]
lst.sort(reverse=True) #降序排序
print(lst) #[99, 88, 77, 66, 55, 44, 33, 22, 11]
六、列表的嵌套
一层一层降维就可以找到需要的元素。
lst = [1, "太⽩", "wusir", ["⻢⻁疼", ["可⼝可乐"], "王剑林"]]
# 找到wusir
print(lst[2])
# 找到太⽩和wusir
print(lst[1:3])
# 找到太⽩的⽩字
print(lst[1][1])
# 将wusir拿到. 然后⾸字⺟⼤写. 再扔回去
s = lst[2]
s = s.capitalize()
lst[2] = s
print(lst)
# 简写
lst[2] = lst[2].capitalize()
print(lst)
# 把太⽩换成太⿊
lst[1] = lst[1].replace("⽩", "⿊")
print(lst)
# 把⻢⻁疼换成⻢化疼
lst[3][0] = lst[3][0].replace("⻁", "化")
print(lst[3][0])
lst[3][1].append("雪碧")
print(lst)
七、元祖
1、元素索引和列表一样
tu = (1, "太⽩", "李⽩", "太⿊", "怎么⿊")print(tu[0])
print(tu[2])
print(tu[2:5]) # 切⽚之后还是元组
2、可以遍历
tu = (1, "太⽩", "李⽩", "太⿊", "怎么⿊")
for el in tu:
print(el)
注意:关于元组不可变的解说,元组不可变的意思是子元素不可变,而子元素内部的子元素是可以变的,这是取决于子元素是否可变。
七、range、join,split
1、range可以帮我们获取到⼀组数据. 通过for循环能够获取到这些数据.
for num in range(10):
print(num)
for num in range(1, 10, 2):
print(num)
for num in range(10, 1, -2): # 反着来, 和切⽚⼀样
print(num)
2、join 把列表拼接为字符串
li = ["李嘉诚", "麻花藤", "⻩海峰", "刘嘉玲"]
s = "_".join(li) #李嘉诚_麻花藤_⻩海峰_刘嘉玲
print(s)
li = "⻩花⼤闺⼥"
s = "_".join(li)
print(s)#⻩_花_⼤_闺_⼥
3、split 把字符串切割返回字典
str="name:json:age:18"
lst=str.split(":")
print(lst)#['name', 'json', 'age', '18']