Python中列表的各种方法
列表是Python中一种常用的存储信息的方式,所以要熟练掌握列表的各种方法:
首先我们定义一个列表(name),然后练习里面的各种方法:
>>> name = ["Sora Aoi","Alex","Ria","sakurai","Ozawa","Maria"]
'append', 'clear', 'copy', 'count', 'extend', 'index', 'insert', 'pop', 'remove', 'reverse', 'sort'
append方法:
L.append(object) -> None -- append object to end
append单词的含义是追加,在Python中也是这样的含义,向列表末尾进行追加元素
>>> name.append("Sora Aoi")
>>> name
['Sora Aoi', 'Alex', 'Ria', 'sakurai', 'Ozawa', 'Maria', 'Sora Aoi']
append()方法是向列表的末尾添加元素,这个方法我们经常用到,定义一个空的列表,向列表中添加元素。
clear()方法:
L.clear() -> None -- remove all items from L (删除列表中所有的值)
>>> name = ["Alex","tom","Aoi"]
>>> name.clear()
>>> name
[]
列表中clear()方法是不需要参数的,clear()方法的作用就是删除列表中的所有元素,这个函数的目的就是删除所有元素,列表中的方法。
copy()方法:
L.copy() -> list -- a shallow copy of L
>>> name = ["gen","Alex","tom"]
>>> name.copy()
['gen', 'Alex', 'tom']
>>> names = name.copy()
>>> names
['gen', 'Alex', 'tom']
copy()方法也不需要参要参数,把列表复制赋值给另外一个列表,列表复制的方法,可以替代有时候使用切片的时候
count()方法:
L.count(value) -> integer -- return number of occurrences of value
conunt()方法是统计一个值(value)在一个列表中(list)出现的次数(发生的次数)
>>> name = ["Aoi","Maria","Alex","Aoi"]
>>> name.count("Aoi")
2
可以看出,count()方法是统计一个值(value)在一个列表中出现的次数,如果这个值没有在这个列表中,则返回0;统计一个值在一个列表中出现的次数,可用于删除这个值在列表中出现的情况,这样能够减少循环的次数,提高运行的效率。
extend()方法:
L.extend(iterable) -> None -- extend list by appending elements from the iterable
>>> name = ["Alex","Ria","Ozawa"]
>>> name_list = ["sora Aoi","sakurai","Maria"]
>>> name.extend(name_list)
>>> name
['Alex', 'Ria', 'Ozawa', 'sora Aoi', 'sakurai', 'Maria']
extend()列表是把两个列表进行合并的方法,有时候我们需要把两个列表进行合并,可以使用extend()方法,这种情况也是很常用的,把一个列表的信息添加到另外一个列表中。合并两个列表。
>>> name
['Alex', 'Ria', 'Ozawa', 'sora Aoi', 'sakurai', 'Maria']
>> a = "tom"
>>> name.extend(a)
>>> name
['Alex', 'Ria', 'Ozawa', 'sora Aoi', 'sakurai', 'Maria', 't', 'o', 'm']
如果是向列表中添加一个字符串的话,那么,列表会遍历字符串中的每个值,然后添加到列表中,遍历字符串中的值,然后添加。
index()方法:
L.index(value, [start, [stop]]) -> integer -- return first index of value.
Raises ValueError if the value is not present.
index()方法是查找指定元素在列表中的位置,index()方法必须指定第一个参数,要查找哪个值在列表中的位置,也可以指定查找的起始位置;如果查找不到,系统会报错,如下所示:
>>> name
['Alex', 'Ria', 'Ozawa', 'sora Aoi', 'sakurai', 'Maria', 'Alex']
>>> name.index("Alex")
0
>>> name.index("Alex",2)
6
>>> name.index("Alex",2,8)
6
>>> name.index("Alex",2,3)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: 'Alex' is not in list
从上面程序可以看出,默认没有指定起始位置的话只查找第一个元素在列表中的位置,可以自己定义起始位置,从什么时候开始,或者从哪里开始到哪个位置结束。如果这个值不在列表中会报错,提示这个值不在列表中。
insert()方法:
L.insert(index, object) -- insert object before index
index是向列表中指定的位置添加元素,有两个参数,index(索引位置),object(值),向列表中指定位置的前面添加元素,占用原来元素的位置。
>>> name
['Alex', 'Ria', 'Ozawa', 'sora Aoi', 'sakurai', 'Maria', 'Alex']
>>> name.insert(2,"Sb")
>>> name
['Alex', 'Ria', 'Sb', 'Ozawa', 'sora Aoi', 'sakurai', 'Maria', 'Alex']
insert()方法是向列表中添加元素,需要两个参数
pop()方法:
L.pop([index]) -> item -- remove and return item at index (default last).
Raises IndexError if list is empty or index is out of range.
pop()方法是弹出列表末尾的元素,并且把这个弹出来的元素赋给一个新的变量,这个方法经常与append()和空列表结合使用,从一个列表中弹出元素进行验证,然后添加到另外一个列表中的情况:
>>> your = name.pop(12)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
IndexError: pop index out of range
>>> name.pop()
'Alex'
>>> name
['Alex', 'Ria', 'Sb', 'Ozawa', 'sora Aoi', 'sakurai', 'Maria']
>>> name.pop(2)
'Sb'
pop()方法是从列表中弹出元素,默认是弹出最后一个元素,也可以指定删除指定索引的值,pop([index]),如果指定的索引超过列表的长度,系统就会报错。
remove()方法:
L.remove(value) -> None -- remove first occurrence of value.
Raises ValueError if the value is not present.
remove()方法是移除列表中第一个出现的指定的值,是指定要移除哪个值,首先是我们知道这个值,然后进行移除的情况
>>> name
['Alex', 'Ria', 'Ozawa', 'sora Aoi', 'sakurai', 'Maria']
>>> name.remove("Alex")
>>> name
['Ria', 'Ozawa', 'sora Aoi', 'sakurai', 'Maria']
我们从列表中移除了"Alex",如果值不存在列表中,则会报错。
reverse()方法:
L.reverse() -- reverse *IN PLACE*
reverse()方法是将列表的元素进行颠倒,单词reverse的含义就是颠倒。
>>> name
['Maria', 'sakurai', 'sora Aoi', 'Ozawa', 'Ria']
>>> name.reverse()
>>> name
['Ria', 'Ozawa', 'sora Aoi', 'sakurai', 'Maria']
方法reverse()是将列表中的元素进行倒转,颠倒,在我们需要把元素进行倒转的时候比较常用。
sort()方法:
L.sort(key=None, reverse=False) -> None -- stable sort *IN PLACE*
sort()方法是对列表进行排序的方法,里面有两个参数,需要指定名字,其中reverse默认时False,即排序后不反转,如果排序后反转的话,则需要注明:reverse=True,另外,字符串和数字是不能在同一个列表中进行排序的,在Python3中。
>>> name
['Ria', 'Ozawa', 'sora Aoi', 'sakurai', 'Maria']
>>> name.append(1)
>>> name
['Ria', 'Ozawa', 'sora Aoi', 'sakurai', 'Maria', 1]
>>> name.sort()
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: unorderable types: int() < str()
>>> name.pop()
1
>>> name
['Maria', 'Ozawa', 'Ria', 'sakurai', 'sora Aoi']
>>> name.sort()
>>> name
['Maria', 'Ozawa', 'Ria', 'sakurai', 'sora Aoi']
>>> name.sort(reverse=True)
>>> name
['sora Aoi', 'sakurai', 'Ria', 'Ozawa', 'Maria']
>>>
从上面程序中我们可以看出,字符串和数字是不能够在一个列表中同时进行排序的(TypeError: unorderable types: int() < str()),在Python3中,排序后也可以直接进行列表反转的操作。
del操作:
del也可以删除列表中的元素,del 列表名[索引]
>>> name
['sora Aoi', 'sakurai', 'Ria', 'Ozawa', 'Maria']
>>> del name[2]
>>> name
['sora Aoi', 'sakurai', 'Ozawa', 'Maria']
Python中列表的各种方法的更多相关文章
- python中列表元素连接方法join用法实例
python中列表元素连接方法join用法实例 这篇文章主要介绍了python中列表元素连接方法join用法,实例分析了Python中join方法的使用技巧,非常具有实用价值,分享给大家供大家参考. ...
- Python中列表的copy方法
1.在列表中存在一个名为copy的方法,就像字面意思一样copy方法是用于复制列表元素的,示例如下: names = [‘Zhangsan’,’Lisi’,’WangErgou’] names2 = ...
- python中列表和元组以及字符串的操作
python中列表是非常好用的.不过有一些使用小细节还需要注意一下. tag[32:-4] 从index为32到tag的倒数第4个字符. 如果索引为32的值在倒数第4个字符的右边,那么将输出为空.只要 ...
- python中List的sort方法的用法
python列表排序 简单记一下python中List的sort方法(或者sorted内建函数)的用法. 关键字: python列表排序 python字典排序 sorted List的元素可以是各种东 ...
- 【转】python中List的sort方法(或者sorted内建函数)的用法
原始出处:http://gaopenghigh.iteye.com/blog/1483864 python列表排序 简单记一下python中List的sort方法(或者sorted内建函数)的用法. ...
- Python中bisect的使用方法
Python中列表(list)的实现其实是一个数组,当要查找某一个元素的时候时间复杂度是O(n),使用list.index()方法,但是随着数据量的上升,list.index()的性能也逐步下降,所以 ...
- Python中列表,元组,字典,集合的区别
参考文档https://blog.csdn.net/Yeoman92/article/details/56289287 理解Python中列表,元组,字典,集合的区别 列表,元组,字典,集合的区别是p ...
- python中列表的insert和append的效率对比
python中insert和append方法都可以向列表中插入数据只不过append默认插入列表的末尾,insert可以指定位置插入元素. 我们来测试一下他俩插入数据的效率: 测试同时对一个列表进行插 ...
- 【转】关于python中re模块split方法的使用
注:最近在研究文本处理,需要用到正则切割文本,所以收索到了这篇文章,很有用,谢谢原作者. 原址:http://blog.sciencenet.cn/blog-314114-775285.html 关于 ...
随机推荐
- 6.UiWatcher API 详细介绍
Tip: 1.监听器不是完能的,所以若用例需要设置监听器防止用例被打断,最好把延迟时间调高一点 2.UiDevice是不会触发监听功能的 3.监听器在方法体或者循环体中是程序还是会被打断的 4.监听器 ...
- cp 带着属性复制过去,
sudo cp -ra store_bak/* store/ -r 所有文件循环都复制 -a 带着属性复制过去
- Tensorflow BatchNormalization详解:2_使用tf.layers高级函数来构建神经网络
Batch Normalization: 使用tf.layers高级函数来构建神经网络 觉得有用的话,欢迎一起讨论相互学习~Follow Me 参考文献 吴恩达deeplearningai课程 课程笔 ...
- [LeetCode] 数学计算模拟类问题:加法,除法和幂,注意越界问题。题 剑指Offer,Pow(x, n) ,Divide Two Integers
引言 数学计算的模拟类题目,往往是要求实现某种计算(比如两数相除),实现的过程中会有所限定,比如不允许乘法等等. 这类题目首先要注意计算过程中本身的特殊情况.比如求相除,则必须首先反映过来除数不能为0 ...
- 2017 国庆湖南 Day3
期望得分:100+30+60=190 实际得分:10+0+55=65 到了233 2是奇数位 或223 第2个2是偶数位就会223 .233 循环 #include<cstdio> #de ...
- 2017.5.27 NOIP模拟赛(hzwer2014-5-16 NOIP模拟赛)
期望得分:100+100+60+30=290 实际得分:100+20+60+0=180 当务之急:提高一次正确率 Problem 1 双色球(ball.cpp/c/pas) [题目描述] 机房来了新一 ...
- CF821 C. Okabe and Boxes 栈模拟
Link 题意:给出操作,如果当前出栈操作使得出栈序列非顺序,可以在此之前自由排序栈中所有数,问最少排几次. 思路:已经出栈到第x个元素时,每次需要排序的操作后,能够保证前x元素出栈有序,否则说明该操 ...
- 《HTML5编程之旅》系列二:Communication 技术初探
本文主要探讨用于构建实时跨源通信的两个模块:跨文档消息通信(Cross Document Messaging)和XMLHttpRequestLevel2.通过这两个模块,我们可以构建不同域间进行安全 ...
- LintCode 395: First Will Win 2
LintCode 395: First Will Win 2 题目描述 有 n 个不同价值的硬币排成一条线.两个参赛者轮流从左边依次拿走 1 或 2 个硬币,直到没有硬币为止.计算两个人分别拿到的硬币 ...
- 【BZOJ】1706: [usaco2007 Nov]relays 奶牛接力跑
[题意]给定m条边的无向图,起点s,终点t,要求找出s到t恰好经过n条边的最短路径.n<=10^6,m<=100. [算法]floyd+矩阵快速幂 [题解] 先对点离散化,得到点数N. 对 ...