下面列出列表常用的方法操作列表以及小例子:
1. Append
在列表末尾添加元素,需在列表末尾添加元素,需要注意幾個點:
A. append中添加的參數是整體
>>> name = list("scott")
>>> name
['s', 'c', 'o', 't', 't']
> >> name.append(list(" tiger"))
>>> name
['s', 'c', 'o', 't', 't', [' ', 't', 'i', 'g', 'e', 'r']]
得到的值不是:['s', 'c', 'o', 't', 't', ' ', 't ', 'i', 'g', 'e', 'r']
如果想要這種的追加方式,可以試試分片賦值(或者下面說到的extend方法):
>>> name = list("scott")
>>> name
['s', 'c', 'o', 't', 't']
>>> name[len(name):] = list(" tiger") #從末尾追加
>>> name
['s', 'c', 'o', 't', 't', ' ', 't', 'i' , 'g', 'e', 'r']
B.append一次只能加入一個元素
>>> name = list("scott")
>>> name
['s' , 'c', 'o', 't', 't']
>>> name.append("A","B") #新增多個元素即將報錯誤
Traceback (most recent call last) :
File "", line 1, in ?
TypeError: append() takes exactly one argument (2 given)
>>> name.append("A") s', 'c', 'o', 't', 't', 'A']
2. Count
統計某一元素在清單中出現的次數
>>> name = list ("scott")
>>> name
['s', 'c', 'o', 't', 't']
>>> name.count('s')
> >> name.count("t")
>>> name.count("A")
>>> name.append(list("Python"))
>>> name
['s ', 'c', 'o', 't', 't', ['P', 'y', 't', 'h', 'o', 'n']]
>>> name .count(['P', 'y', 't', 'h', 'o', 'n'])
3. Extend
在原始列表追加另一個序列的中的多個值
>>> name = list("scott")
>>> name
['s', 'c', 'o', 't', 't']
>>>> name.extend (list(" tiger"))
>>> name
['s', 'c', 'o', 't', 't', ' ', 't', 'i', 'g ', 'e', 'r']
當然,我們可以用分片賦值來實現:
>>> name = list("scott")
>>> name
['s', ' c', 'o', 't', 't']
>>> name[len(name):] = list(" tiger")
>>> name
['s', 'c ', 'o', 't', 't', ' ', 't', 'i', 'g', 'e', 'r']
這時小夥伴們會想到,我們可以直接用運算子"+"嘛,還方便一點:
>>> name = list("scott")
>>> pwd = list(" tiger")
>>> name + pwd
[' s', 'c', 'o', 't', 't', ' ', 't', 'i', 'g', 'e', 'r']
>>> name
['s', 'c', 'o', 't', 't']
從這三種方式操作的輸出,可以看出:
extend和分片賦值都是修改原列表,相對而言,extend可讀性強些,而操作符"+"是產生一個新的列表,不影響原始列表,如果
我們需要產生新列表而不影響原列表,就可以用操作符"+" 。
4.Index
從列表中找出某個值第一個(注意是第一個)匹配項的索引位置
>>>name = list("scott")
>>>> name
['s', 'c', 'o', 't', 't']
>>> name.index('t') ##第一個字母t的索引位置是3
>>> name.index('a')
Traceback (most recent call last):
File "", line 1, in ?
File "", line 1, in ?,Error: list. >>> 'a' in nameFalse>>> 'a' not in nameTrue從輸出可以看出,index找的是第一個匹配項的索引位置,而如果尋找的元素不在列表中,會報錯(返回-1會不會好一點呢?),當然如果想避免報錯,我們可以先用in操作,判斷某個元素是否在某個列表中,如果在的話,然後進行index操作。 5. Insert 用於將物件插入到清單中,兩個參數,第一個是索引位置,第二個插入的元素物件。 >>> name = list("scott")>>> name
['s', 'c', 'o', 't', 't']
>>> name.insert(2,'tiger') ##在索引為2的地方插入字串tiger
>>> name
['s', 'c', 'tiger', 'o', 't', 't']
我們也可以用分片賦值:
>>> name = list("scott")
>>> name
['s', 'c', 'o', 't', 't']
>>> name[2:2 ] = ['tiger']
>>> name
['s', 'c', 'tiger', 'o', 't', 't']
>>> name[2:2 ] = 'tiger'
>>> name
['s', 'c', 't', 'i', 'g', 'e', 'r', 'tiger', 'o', 't', 't']
這裡需要注意的是,如果是插入一個元素,需要用[]括起來,不然,直接用字符串的話,是插入字符串的列表,在索引位置之後添加。
當然,用insert的可讀性比分片賦值強。
6. Pop
移除清單中的一個元素(最後一個元素),並傳回該元素的值
>>> name = list("scott")
>>> name = list("scott")>'s', 'c', 'o', 't', 't']
>>> name.pop()
't'
>>> name
['s', 'c ', 'o', 't']
>>> name.append("t")
>>> name
['s', 'c', 'o', 't', 't ']
分片賦值模擬pop:
>>> name = list("scott")
>>> name
['s', 'c', 'o', 't', 't ']
>>> name[len(name)-1:] = []
>>> name
['s', 'c', 'o', 't']
這上面用pop和append模擬了棧的先進先出LIFO。
7. Remove
移除列表中某個值的第一個匹配項: 如果有兩個相等的元素,就只是移除匹配的一個元素,如果某元素不存在某列表中,便會報錯,而且一次性只能
移除一個元素。
>>> name = list("scott")
>>> name
['s', 'c', 'o', 't', 't']
>>>> name.remove ("t") #去掉第一個t
>>> name
['s', 'c', 'o', 't']
>>> name.remove("A") #不存在會報錯
Traceback (most recent call last):
File "", line 1, in ?
ValueError: list.remove(x): x not in list
> name
True
>>> name.remove("s","c") #一次只能移除一個元素
Traceback (most recent call last):
?
TypeError: remove() takes exactly one argument (2 given)
8.Revense
將清單中的元素反向
8.Revense 將清單中的元素反向
['s', 'c', 'o', 't', 't']
>>> name.reverse()
>>> name
['t', 't', 'o', 'c', 's']
9. Sort & Sorted
sort方法用於對列表進行排序,修改原始列表,不會返回一個已排序的列表副本
>>>> result = [8,5,5,3,9]
>>> result.sort()
>>> result
[3, 5, 5, 8, 9]
如果我們想要回傳一個已排序的列表副本,而不影響原來的列表呢,一種方法,我們可以先賦值原來列表(可以用分片賦值複製),然後
在複製的列表上做sort操作,另一種方法,就是使用sorted函數,它會傳回已排序的清單副本:
>>> result = [8,5,5,3,9]
>>> result2 = sorted(result)
>>>> result
[8, 5, 5, 3, 9]
>>> result2
[3, 5, 5, 8, 9]