Python列表常用函数使用详解
作者:士别三日wyx 发布时间:2021-08-21 01:52:05
介绍
append()
语法
list.append( element )
参数
element:任何类型的元素
列表「末尾」添加元素
name_list = ['zhangsan', 'lisi', 'wangwu']
name_list.append('zhaoliu')
print(name_list)
输出:
['zhangsan', 'lisi', 'wangwu', 'zhaoliu']
列表末尾可添加 「任意类型」数据,比如在列表中添加列表
name_list = ['zhangsan', 'lisi', 'wangwu']
name_list.append([1,2,3])
print(name_list)
输出:
['zhangsan', 'lisi', 'wangwu', [1, 2, 3]]
append() 函数添加的是「地址」,当被添加的列表发生变化时,添加后的列表也会 「同步变化」
list1 = ['zhangsan']
a = [1,2,3]
list1.append(a) # 列表list1添加列表a
print(list1)
a.append(4) # 列表a发生变化
list1.append(a)
print(list1) # 列表list1也会同步变化
输出:
['zhangsan', [1, 2, 3]]
['zhangsan', [1, 2, 3, 4], [1, 2, 3, 4]]
补充两个概念:
浅拷贝:拷贝这个对象的引用
深拷贝:拷贝对象的内容
「深拷贝」可解决 append() 函数添加列表的同步问题
list1 = ['zhangsan']
a = [1,2,3]
list1.append(copy.deepcopy(a)) # 深拷贝列表a
print(list1)
a.append(4) # 列表a发生变化
list1.append(copy.deepcopy(a)) # 深拷贝列表a
print(list1) # 列表list1不再同步变化
输出:
['zhangsan', [1, 2, 3]]
['zhangsan', [1, 2, 3], [1, 2, 3, 4]]
append() 函数和 extend() 函数的区别
1.append() 添加的是元素「引用」,而 extend() 添加的是元素的「值」
2.append() 可以添加「任意类型」元素,而 extend() 只能添加「序列」
比如,添加列表时, append() 会添加整个列表,而 extend() 只会添加列表中的值
list1 = ['zhangsan', 'lisi', 'wangwu']
list2 = ['zhangsan', 'lisi', 'wangwu']
list1.append([1,2,3])
print('append添加整个列表:', list1)
list2.extend([1,2,3])
print('extend添加列表的值:', list2)
输出:
append添加整个列表: ['zhangsan', 'lisi', 'wangwu', [1, 2, 3]]
extend添加列表的值: ['zhangsan', 'lisi', 'wangwu', 1, 2, 3]
extend()
语法
list.extend(iterable)
参数
iterable:任何可迭代对象(列表、元祖等)
向列表 「末尾」添加列表内容
list1 = ['zhangsan', 'lisi', 'wangwu']
list1.extend([1,2,3]) # 列表末尾添加列表
print(list1)
list1.extend((4,5,6)) # 列表末尾添加元祖
print(list1)
输出:
['zhangsan', 'lisi', 'wangwu', 1, 2, 3]
['zhangsan', 'lisi', 'wangwu', 1, 2, 3, 4, 5, 6]
Python中的 「字符串」本质上也是一种数组,属于可迭代对象,可以使用 extend() 添加
list1 = ['zhangsan', 'lisi', 'wangwu']
list1.extend('abc') # 列表末尾添加字符串
print(list1)
输出:
['zhangsan', 'lisi', 'wangwu', 'a', 'b', 'c']
insert()
语法
list.insert( index, element)
参数
index:数字,指定插入的位置
element:任意类型,需要插入的元素
insert() 函数可以添加「任意类型」
list1 = ['zhangsan', 'lisi']
list1.insert(2, 2) # 添加整形
print(list1)
list1.insert(3, 'str') # 添加字符串
print(list1)
list1.insert(4, [1,2,3]) # 添加列表
print(list1)
list1.insert(5, (4,5,6)) # 添加字典
print(list1)
输出:
['zhangsan', 'lisi', 2]
['zhangsan', 'lisi', 2, 'str']
['zhangsan', 'lisi', 2, 'str', [1, 2, 3]]
['zhangsan', 'lisi', 2, 'str', [1, 2, 3], (4, 5, 6)]
insert同样存在 「列表同步」问题,改为 「软拷贝」即可
list1 = ['zhangsan', 'lisi']
a = [1,2,3]
list1.insert(2, a) # 添加列表a
print(list1)
a.append(4) # 列表a发生变化
print(list1) # 列表同步发生变化
输出:
['zhangsan', 'lisi', [1, 2, 3]]
['zhangsan', 'lisi', [1, 2, 3, 4]]
pop()
语法
list.pop( index )
参数
index:数字,需要删除的索引位置,默认值-1
返回值:删除的值
不传参数时,默认删除「最后」一个值
list1 = [1, 2, 3, 4]
list1.pop()
print(list1)
输出:
[1, 2, 3]
删除 「指定」位置的元素
list1 = [1, 2, 3, 4]
list1.pop(1) # 删除第二个值
print(list1)
输出:
[1, 3, 4]
「返回」被删除的元素
list1 = [1, 2, 3, 4]
a = list1.pop(1) # 删除第二个值,并返回被删除的值
print(a)
输出:
2
remove()
语法
list.remove( element )
参数
element:任意数据类型
remove() 函数删除「普通类型」元素
list1 = ['zhangsan', 'lisi', 1, 2]
list1.remove(1) # 删除数字
print(list1)
list1.remove('zhangsan') # 删除字符串
print(list1)
输出:
['zhangsan', 'lisi', 2]
['lisi', 2]
remove() 函数删除 「对象类型」元素
list1 = [1, 2, [3, 4], (5, 6)]
a = [3, 4]
b = (5, 6)
list1.remove(a) # 删除列表类型
print(list1)
list1.remove(b) # 删除元祖类型
print(list1)
输出:
[1, 2, (5, 6)]
[1, 2]
remove() 函数删除对象类型的「前提」是,列表中的元素是对象类型,以下这种方式会报错
list1 = [1, 2, 3, 4, 5]
list1.remove([1,2])
输出:
Traceback (most recent call last):
File "E:/data/PrCharm/test1/55.py", line 2, in <module>
list1.remove([1,2])
ValueError: list.remove(x): x not in list
# 值错误: 需要删除的值不在列表中
remove() 函数「一次」只能删除一维数组中的「一个」元素,自己删自己也不行
list1 = [1, 2, 3, 4, 5]
print('我自己在我自己里面吗?', list1 in list1)
list1.remove(list1)
输出:
Traceback (most recent call last):
File "E:/data/PrCharm/test1/55.py", line 3, in <module>
list1.remove(list1)
ValueError: list.remove(x): x not in list
我自己在我自己里面吗? False
来源:https://blog.csdn.net/wangyuxiang946/article/details/122238775


猜你喜欢
- 该计算器功能:1.校验:小数点,重复计算,以及大量更符合用户体验的操作。2.能够从键盘输入。效果图:html代码:<!DOCTYPE
- 今天刚好需要配置mysql 5.5.45,因为数据库量挺大的,所以必须优化,要不mysql真的不快。(1)、max_connections:
- 一、需求说明能够根据模板批量生成docx文档。具体而言,读取excel中的数据,然后使用python批量生成docx文档。二、实验准备准备e
- 没事在这里发一下关于数据库大批量插入数据的效率对比,用ACCESS和MSSQL,数值是在本机测试,根据不同的环境和配置,数值可能会有较大差别
- 清除浮动这个问题的提出,在现在来说应该算是一个非常古老的问题了,很多人对解决办法估计也能烂记于心了,但是我这个落后了不少的前端开发程序员,太
- 美化主要表现在鼠标放到菜单上后(即鼠标悬停)的效果,这里首先介绍几个经常用到的CSS属性:backgr
- PyAutoGUI是一个Python语言的键鼠自动化库,简单来说和按键精灵的功能一样。但是因为是Python的类库,所以可以使用Python
- 本文是基于opencv将视频和动态图gif保存为图像帧。可以根据输入视频格式的不同,修改第21行。 &nb
- 方法一:def str_count(str): '''找出字符串中的中英文、空格、数字、标点符号个数'
- 本文实例讲述了Python实现桶排序与快速排序算法结合应用的方法。分享给大家供大家参考,具体如下:#-*- coding: UTF-8 -*
- 文件的数据是存放于硬盘上的,因而只存在覆盖、不存在修改这么一说,我们平时看到的修改文件,都是模拟出来的效果,具体的说有两种实现方式。一、方式
- 本文实例讲述了Sql Server事务语法及使用方法。分享给大家供大家参考,具体如下:事务是关于原子性的。原子性的概念是指可以把一些事情当做
- 1.tensor张量与numpy相互转换tensor ----->numpyimport torcha=torch.ones([2,5
- 用于加密相关的操作,3.x里代替了md5模块和sha模块,主要提供 SHA1, SHA224, SHA256, SHA384, SHA512
- 业务背景业务需求要求开发一个异步上传文件的接口,并支持上传进度的查询。需求分析ZIP压缩包中,包含一个csv文件和一个图片文件夹,要求:解析
- 使用matplotlib生成图片,想要背景透明,而且图例部分也显示透明效果,找到了大概的设置方法,特此记录。# coding=utf-8#
- 最近做项目需要我们前端对金额进行千分位格式化(也就是说每三位用逗号隔开),代码已经做了修改 之前的版本是本人疏忽 真对不住大家了
- 集合的特性无序、不重复、可迭代常用api创建一个集合需要显式地使用set()方法来声明,如果使用字面量{}来声明解析器会认为这是一个字典。a
- 1. 文件锁脚本启动前检查特定文件是否存在,不存在就启动并新建文件,脚本结束后删掉特定文件。通过文件的判断来确定脚本是否正在执行。方法实现也
- 之前用Python 2.7版本的httplib做接口测试时,运行代码都是正常的,最近开始用Python 3.3之后,再去看以前的代码,发现i