Python操作列表的常用方法分享
下面列出列表常用的方法操作列表以及小例子:
1. Append
在列表末尾添加元素,需在列表末尾添加元素,需要注意幾個(gè)點(diǎn):
A. append中添加的參數(shù)是作為一個(gè)整體
>>> 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']
如果想要這種的追加方式,可以試試分片賦值(或者下面說(shuō)到的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一次性只能添加一個(gè)元素
>>> name = list("scott")
>>> name
['s', 'c', 'o', 't', 't']
>>> name.append("A","B") #添加多個(gè)元素即將報(bào)錯(cuò)
Traceback (most recent call last):
File "<stdin>", line 1, in ?
TypeError: append() takes exactly one argument (2 given)
>>> name.append("A")
>>> name
['s', 'c', 'o', 't', 't', 'A']
2. Count
統(tǒng)計(jì)某個(gè)元素在列表中出現(xiàn)的次數(shù)
>>> name = list("scott")
>>> name
['s', 'c', 'o', 't', 't']
>>> name.count('s')
1
>>> name.count("t")
2
>>> name.count("A")
0
>>> name.append(list("Python"))
>>> name
['s', 'c', 'o', 't', 't', ['P', 'y', 't', 'h', 'o', 'n']]
>>> name.count(['P', 'y', 't', 'h', 'o', 'n'])
1
3. Extend
在原列表追加另一個(gè)序列的中的多個(gè)值
>>> name = list("scott")
>>> name
['s', 'c', 'o', 't', 't']
>>> name.extend(list(" tiger"))
>>> name
['s', 'c', 'o', 't', 't', ' ', 't', 'i', 'g', 'e', 'r']
當(dāng)然,我們可以用分片賦值來(lái)實(shí)現(xiàn):
>>> 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']
這時(shí)小伙伴們會(huì)想到,我們可以直接用操作符"+"嘛,還方便些:
>>> 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和分片賦值都是修改原列表,相對(duì)而言,extend可讀性強(qiáng)些,而操作符"+"是生成一個(gè)新的列表,不影響原列表,如果
我們需要生成新列表而不影響原列表,就可以用操作符"+"。
4.Index
從列表中找出某個(gè)值第一個(gè)(注意是第一個(gè))匹配項(xiàng)的索引位置
>>> name = list("scott")
>>> name
['s', 'c', 'o', 't', 't']
>>> name.index('t') ##第一個(gè)字母t的索引位置是3
3
>>> name.index('a')
Traceback (most recent call last):
File "<stdin>", line 1, in ?
ValueError: list.index(x): x not in list
>>> 'a' in name
False
>>> 'a' not in name
True
從輸出可以看出,index找的是第一個(gè)匹配項(xiàng)的索引位置,而如果查找的元素不在列表中,會(huì)報(bào)錯(cuò)(返回-1會(huì)不會(huì)好一點(diǎn)呢?),當(dāng)然如果想避免報(bào)
錯(cuò),我們可以先用in操作,判斷某個(gè)元素是否在某個(gè)列表中,如果在的話,然后進(jìn)行index操作。
5. Insert
用于將對(duì)象插入到列表中,倆個(gè)參數(shù),第一個(gè)是索引位置,第二個(gè)插入的元素對(duì)象。
>>> 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']
這里需要注意的是,如果是插入一個(gè)元素,需要用[]括起來(lái),不然,直接用字符串的話,是插入字符串的列表,在索引位置之后添加。
當(dāng)然,用insert的可讀性比分片賦值強(qiáng)。
6. Pop
移除列表中的一個(gè)元素(最后一個(gè)元素),并返回該元素的值
>>> name = list("scott")
>>> name
['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模擬了棧的先進(jìn)先出LIFO。
7. Remove
移除列表中某個(gè)值的第一匹配項(xiàng): 如果有倆個(gè)相等的元素,就只是移除匹配的一個(gè)元素,如果某元素不存在某列表中,便會(huì)報(bào)錯(cuò),而且一次性只能
移除一個(gè)元素。
>>> name = list("scott")
>>> name
['s', 'c', 'o', 't', 't']
>>> name.remove("t") #去掉第一個(gè)t
>>> name
['s', 'c', 'o', 't']
>>> name.remove("A") #不存在會(huì)報(bào)錯(cuò)
Traceback (most recent call last):
File "<stdin>", line 1, in ?
ValueError: list.remove(x): x not in list
>>> "A" not in name
True
>>> name.remove("s","c") #一次只能移除一個(gè)元素
Traceback (most recent call last):
File "<stdin>", line 1, in ?
TypeError: remove() takes exactly one argument (2 given)
8.Revense
將列表中的元素反向
>>> name = list("scott")
>>> name
['s', 'c', 'o', 't', 't']
>>> name.reverse()
>>> name
['t', 't', 'o', 'c', 's']
9. Sort & Sorted
sort方法用于對(duì)列表進(jìn)行排序,修改原列表,不會(huì)返回一個(gè)已排序的列表副本
>>> result = [8,5,5,3,9]
>>> result.sort()
>>> result
[3, 5, 5, 8, 9]
如果我們想要返回一個(gè)已排序的列表副本,而不影響原來(lái)的列表呢,一種方法,我們可以先賦值原來(lái)列表(可以用分片賦值復(fù)制),然后
在復(fù)制的列表上做sort操作,另一種方法,就是使用sorted函數(shù),它會(huì)返回已排序的列表副本:
>>> result = [8,5,5,3,9]
>>> result2 = sorted(result)
>>> result
[8, 5, 5, 3, 9]
>>> result2
[3, 5, 5, 8, 9]
關(guān)于自定義的比較方法,像javascript做sort可以傳入compare函數(shù),java可以傳入Comparable<T>實(shí)例,Python也類似,留待后續(xù)了~(@^_^@)~。
相關(guān)文章
python模塊shutil函數(shù)應(yīng)用示例詳解教程
這篇文章主要為大家介紹了python模塊中shutil函數(shù)的應(yīng)用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2021-10-10
python 如何將office文件轉(zhuǎn)換為PDF
這篇文章主要介紹了python 如何將office文件轉(zhuǎn)換為PDF,幫助大家更好的理解和使用python,感興趣的朋友可以了解下2020-09-09
Python中super關(guān)鍵字用法實(shí)例分析
這篇文章主要介紹了Python中super關(guān)鍵字用法,實(shí)例分析了super關(guān)鍵字的功能及相關(guān)使用技巧,需要的朋友可以參考下2015-05-05
Python使用Streamlit快速構(gòu)建一個(gè)數(shù)據(jù)應(yīng)用程序
Streamlit是一個(gè)開(kāi)源的Python庫(kù),它允許數(shù)據(jù)科學(xué)家和開(kāi)發(fā)人員快速創(chuàng)建和分享數(shù)據(jù)應(yīng)用程序,而無(wú)需具備復(fù)雜的Web開(kāi)發(fā)經(jīng)驗(yàn),本文將介紹Streamlit的基本用法,并通過(guò)一個(gè)實(shí)際案例展示如何快速構(gòu)建一個(gè)簡(jiǎn)單的數(shù)據(jù)應(yīng)用程序,需要的朋友可以參考下2025-03-03
Python中eval()函數(shù)的詳細(xì)使用教程
eval函數(shù)在Python中具有非常重要的地位,熟練的使用eval函數(shù)能夠?yàn)槲覀兊腜ython編程提供很多的便利之處,下面這篇文章主要給大家介紹了關(guān)于Python中eval()函數(shù)的詳細(xì)使用,需要的朋友可以參考下2022-07-07
在Linux系統(tǒng)上安裝Python的Scrapy框架的教程
這篇文章主要介紹了在Linux系統(tǒng)上安裝Python的Scrapy框架的教程,Scrapy是著名的專門針對(duì)搜索引擎的爬蟲(chóng)制作而研發(fā)的Python框架,需要的朋友可以參考下2015-06-06
python中68個(gè)內(nèi)置函數(shù)的總結(jié)與介紹
這篇文章主要介紹了python中68個(gè)內(nèi)置函數(shù)的總結(jié)與介紹,需要的朋友可以參考下2020-02-02
Python 超時(shí)請(qǐng)求或計(jì)算的處理方案
這篇文章主要介紹了Python 超時(shí)請(qǐng)求或計(jì)算的處理方案,本文給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧2024-06-06
python對(duì)兩個(gè)數(shù)組進(jìn)行合并排列處理的兩種方法
最近遇到數(shù)組合并問(wèn)題,以此記錄解決方法,供大家參考學(xué)習(xí),下面這篇文章主要給大家介紹了關(guān)于python對(duì)兩個(gè)數(shù)組進(jìn)行合并排列處理的兩種方法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-05-05

