2024年最新Python大数据之Python基础【五】(列表)_大数据基础应用字典的代码是啥(1)

文章详细介绍了Python列表的各种操作,包括insert和append的区别、删除方法如del、pop和remove的用法,以及如何修改列表、遍历和处理嵌套列表。强调了使用索引和避免索引错误的重要性。
摘要由CSDN通过智能技术生成

格式:列表.insert(要插入位置的索引, 要插入的对象)

在insert中第一个参数是要插入位置的索引,所以如果插入了数,则该被插入数据的索引变为第一参数所显示的索引

原来该位置的元素以及之后的元素下标+1(向后移动一位)

如果使用insert进行 插入,可能会造成索引混乱,原来引用的索引发生错误

在开发中除非明确所有的索引引用都修改完成,否则不要使用insert

append 插入数据,要比insert插入数据更安全

num_list.insert(1, 5)
print(num_list)

extend 和append 进行对比

list1 = [1, 2, 3, 4]
list2 = [5, 6, 7, 8]

append将list2 当做一个元素追加到列表末尾

list1.append(list2) # [1, 2, 3, 4, [5, 6, 7, 8]]

extend将list2 当做多个元素进行拆分后追加

list1.extend(list2) # [1, 2, 3, 4, 5, 6, 7, 8]
print(list1)


### 3、列表中的删除


* del 先对列表中的元素进行查找(使用下标),找到后使用del删除
* pop:删除类表中指定下标位置的元素,如果不指定默认删除最后一个,并且返回被删除的值
* remove:删除指定值的下标,只删除丛左至右的第一次出现的该值元素
* clear:清空列表,和重新赋值为空有逻辑上的区别。



del 将数据引用切断

list1 = [1, 2, 3, 4]

del list1

NameError: name ‘list1’ is not defined

del不仅可以删除元素,也可以删除任何变量,非常强大,但是有些不安全

print(list1)

那del 怎样删除元素呢? 通过索引获取当前元素,并删除

del list1[2]

IndexError: list assignment index out of range

使用下标查找数据时,下标索引不能不存在

del list1[9]

print(list1) # [1, 2, 4]

如果要是循环中能够删除么?

此处并没有删除,因为i是临时变量,我们使用del是在讲i和2的引用关系删除,但是list1 和 2 的引用关系没有删除

for i in list1:

if i == 2:

del i

print(list1)

pop 删除指定索引的元素,并且返回该元素

list1 = [1, 2, 3, 4]

删除后可以返回被删除的对象

print(list1.pop(2))

IndexError: pop index out of range

使用pop进行删除的元素下标一定要存在

print(list1.pop(12))

删除后,指定索引位置的元素消失后边的元素统一向左移动一位

pop也会造成索引变换

print(list1)

如果不给pop进行传值,默认删除最后一个元素

print(list1.pop())

查看删除后结果

print(list1)

remove 删除指定的元素(从左至右第一次出现的元素)

list1 = [1, 2, 3, 3, 4, 2, 1]

删除列表中的2

将从左至右查询第一次遇到的2进行了删除,并不能删除类表中所有的的2

list1.remove(2)
print(list1) # [1, 3, 3, 4, 2, 1]

remove会返回被删除的内容? 不会

print(list1.remove(3)) # None

remove删除的内容不存在会怎样?

list1.remove(123) # ValueError: list.remove(x): x not in list

clear 清空列表

就是讲列表置为[],但是与list1 = [] 有本质区别

list1.clear()
print(list1) # []


### 4、列表的修改


* 使用索引修改: 列表[索引] = 新值
	+ 查询列表索引值必须在列表中存在
* reverse: 列表的反转
* sort:列表的排序,默认为升序
	+ reverse:可以进行列表倒排,降序
	+ key:添加函数,使排序规则更加复杂多变



通过索引进行修改

list1 = [1, 2, 3, 4]

通过索引查找到指定位置的数据,并进行修改

list1[1] = 6

IndexError: list assignment index out of range

获取的元素位置,必须是存在的

list1[6] = 6

print(list1)

通过索引修改可以同时修改多个值么? 不能

list1[(2,3)] = 6,7

可以使用对多变量赋值的形式修改多个值

list1[2], list1[3] = 6, 7
print(list1)

reverse 列表的反转

list1 = [1, 2, 3, 4]

列表反转后,索引倒置,并且在原数据上修改,没有产生新的列表

print(list1.reverse()) # None
print(list1) # [4, 3, 2, 1]

sort 排序

list2 = [2, 6, 43, 2, 41, 421]

sort是对原有的数据进行了排序,没有产生新的列表.同时,默认排序规则为升序

print(list2.sort()) # None

print(list2) # [2, 2, 6, 41, 43, 421]

如果我想让列表降序排列怎么办?

方法一:可以先排序再反转

list2.sort()

list2.reverse()

print(list2) # [421, 43, 41, 6, 2, 2]

方法二: 可以直接使用倒叙排列

list2.sort(reverse=True) # [421, 43, 41, 6, 2, 2]

print(list2)

list2.sort(key=排序规则函数)可以帮助我们进行更加复杂的排序

根据每个元素 % 7 的余数大小进行排序

了解, 不要求掌握 后续会讲

list2.sort(key=lambda x: x % 7)
print(list2)


### 5、列表遍历


* for遍历
* while遍历



while遍历列表

len()函数可以查询列表的长度

list1 = [12, 123, 1, 1, 1234, 12, 34, 8]

print(len(list1))

i = 0
while i < len(list1):
print(list1[i])
i += 1

for 遍历列表

推荐使用for循环遍历容器类型(数据序列)

for i in list1:
print(i)


### 6、列表的嵌套


* 列表中嵌套其他的子列表,就是列表的嵌套
* 嵌套后的列表可以使用循环嵌套来进行遍历



列表的嵌套: 在一个列表中包含其他的列表元素

name_list = [[‘小明’, ‘小红’, ‘小绿’], [‘Tom’, ‘Lily’, ‘Rose’], [‘张三’, ‘李四’, ‘王五’]]

需求:想要获取李四的值

获取李四所在的子列表的索引,并通过索引获取该子列表值

print(name_list[2])

再从子列表中通过李四所在的索引获取其值

print(name_list[2][1])

如果我们想要获取嵌套列表中的每一个值,我们需要怎么做?

如果进行一次循环,每次循环所得到的都一级列表中的元素,也就是每一个子列表

for i in name_list:
print(i)

如果想要对嵌套后的列表进行输出,需要进行循环嵌套

for sub_list in name_list:
for name in sub_list:
print(name)

这样就可以进行所有名称的输出了

如果当前的列表内的数据不都是子列表,有其他数据类型的数据,则不能直接使用循环嵌套,需要先进行类型判断


### 后记


📢博客主页:<https://manor.blog.csdn.net>


📢欢迎点赞 👍 收藏 ⭐留言 📝 如有错误敬请指正!  
 📢本文由 Maynor 原创,首发于 CSDN博客🙉  


![img](https://img-blog.csdnimg.cn/img_convert/65d19e784546ee8947091c4e505a6b16.png)
![img](https://img-blog.csdnimg.cn/img_convert/9a1e3de932ac85040400e93114e93927.png)
![img](https://img-blog.csdnimg.cn/img_convert/011de4f9f1d35c5d9706ef7d1a975c14.png)

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618545628)**

3695091)]

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上大数据知识点,真正体系化!**

**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**

**[需要这份系统化资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618545628)**

  • 8
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值