07python列表

来源:https://www.cnblogs.com/palien/archive/2022/11/15/16893573.html
-Advertisement-
Play Games

這篇文章主要介紹列表的一些知識。 函數list 首先需要說明的是,列表與元組、字元串一樣都是一種序列,但不同的是列表是可變的,即可修改其內容。 因為不能像修改列表那樣修改字元串,所以有些情況下使用字元串來創建列表很有幫助,函數list可以用來創建列表。 >>> list('hello') ['h', ...


這篇文章主要介紹列表的一些知識。

函數list

首先需要說明的是,列表與元組、字元串一樣都是一種序列,但不同的是列表是可變的,即可修改其內容。

因為不能像修改列表那樣修改字元串,所以有些情況下使用字元串來創建列表很有幫助,函數list可以用來創建列表。

>>> list('hello')
['h', 'e', 'l', 'l', 'o']
>>>
>>> ''.join(['h', 'e', 'l', 'l', 'o']) 
'hello'
  • 註意,可以將任何序列(而不僅僅是字元串)作為list的參數。
  • 字元列表也可以轉換為字元串,需要用到關鍵字join。

基本的列表操作

可對列表執行所有標準序列操作,如索引、切片、拼接、相乘,元素檢查等,
但是因為列表是可變的,所以列表還有一些特有的修改元素的操作。

  • 修改列表:給元素賦值

修改列表可有使用賦值語句,但是需要結合索引使用:

>>> 
>>> x = [1, 2, 3, 4, 5]  
>>> x[1] = 'h' 
>>> x
[1, 'h', 3, 4, 5]
>>> 

註意,不能給不存在的元素賦值,即索引不能超出list範圍

  • 刪除元素

從列表中刪除元素,使用del語句:

>>> 
>>> names = ['Alice', 'Beth', 'Cecil', 'Dee-Dee', 'Earl']
>>> del names[2]
>>> names
['Alice', 'Beth', 'Dee-Dee', 'Earl']
>>>
  • 給切片賦值

序列的切片是一項極其強大的功能,列表中還能夠給切片賦值

>> 
>>> name = list('Perl')
>>> name
['P', 'e', 'r', 'l']
>>> name[2:] = list('ar')
>>> name
['P', 'e', 'a', 'r']
>>>
>>> name = list('Perl')
>>> name[1:] = list('python') 
>>> name
['P', 'p', 'y', 't', 'h', 'o', 'n']
>>> 
>>> numbers = [1, 5]
>>> numbers[1:1] = [2, 3, 4]
>>> numbers
[1, 2, 3, 4, 5]
>>> numbers[1:4] = []  # 等效於 del numbers[1:4] 
>>> numbers
[1, 5]
>>>

可以同時給多個元素賦值,通過切片賦值;
還可以將切片替換為長度與其不同的序列;
使用切片賦值還可以在不替換原有元素的情況下插入新的元素

列表方法

方法是與對象(列表、數、字元串等)聯繫緊密的函數,調用方法語法為:object.method(arguments).

  • append()

方法append用於將一個對象附加到列表的末尾。

>>> 
>>> lst = [1, 2, 3]
>>> lst.append(4)   
>>> lst
[1, 2, 3, 4]
>>>

append只能就地修改列表,並不會返回修改後的新列表,而是直接修改舊列表。

關於命名:

  1. 不要與python關鍵字重覆,否則會出現無法調用同名關鍵字函數的情況
  2. 做到“見名知意”,例如列表的名稱為prices、prices_of_eggs、pricesOfEgges
  • clear()

方法clear就地清空列表的內容。

>>> 
>>> lst = [1, 2, 3]
>>> lst.clear() # 等價於賦值語句 lst[:] = []
>>> lst
[]
>>>
  • copy()

方法copy複製列表。

>>> 
>>> a = [1, 2, 3]
>>> b = a
>>> b[1] = 4
>>> a
[1, 4, 3]
>>> c = a.copy() 
>>> c[1] = 5
>>> a
[1, 4, 3]
>>> c
[1, 5, 3]
>>>

常規複製只是將另一個表名關聯到列表,例如 b = a , 修改 b 的元素值實際上就是修改 a 的元素值

通過 copy複製是通過將 c 關聯到 a 的副本創建一個新的列表,修改 c 的元素值不會影響 a 中元素值。此時類似於 a[:]list(a)

  • count()

方法count計算指定的元素在列表中出現了多少次。

>>> 
>>> ['to', 'be', 'or', 'not', 'to', 'be'].count('to')
2   
>>> 
>>> x = [[1, 2], 1, 1, [2, 1, [1, 2]]]
>>> x.count(1)
2   
>>> x.count([1, 2])
1   
>>> 
  • extend()

方法extend能夠同時將多個值添加到列表末尾,為此可以將這些值組成的序列作為參數,即可使用一個列表來拓展另一個列表。

>>> 
>>> a = [1, 2, 3] 
>>> b = [4, 5, 6]
>>> a.extend(b) 
>>> a
[1, 2, 3, 4, 5, 6]
>>> a.extend(7,8,9)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: list.extend() takes exactly one argument (3 given)
>>>
>>> a = [1, 2, 3] 
>>> b = [4, 5, 6]
>>> a + b
[1, 2, 3, 4, 5, 6]
>>> a
[1, 2, 3]
>>>
>>> a = [1, 2, 3] 
>>> b = [4, 5, 6]   
>>> a = a + b # 使用拼接達到extend的效果,但是效率比較低
>>> a
[1, 2, 3, 4, 5, 6]
>>>
>>> a = [1, 2, 3] 
>>> b = [4, 5, 6]
>>> a[len(a):] = b # 切片實現相同的效果,可行,但是可讀性不高
>>> a
[1, 2, 3, 4, 5, 6]
>>>

extend方法的使用類似於拼接,但是重要差別是會修改被拓展的序列,而拼接返回的是一個全新的序列。
拼接的原理是使用a和b的副本創建一個新列表,使用拼接達到相同的效果時,拼接的效率比較低,或者使用切片完成。

  • index()

方法index在列表中查找指定值第一次出現的索引。

>>> 
>>> knights = ['We', 'are', 'the', 'knights', 'who', 'say', 'ni']
>>> knights.index('who')
4
>>> knights.index('herring')
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ValueError: 'herring' is not in list
>>> knights[4]            
'who'
>>>
  • insert()

方法insert用於將一個對象插入列表。

>>> 
>>> numbers = [1, 2, 3, 5, 6, 7]
>>> numbers.insert(3, 'four')
>>> numbers
[1, 2, 3, 'four', 5, 6, 7]
>>>
>>> numbers = [1, 2, 3, 5, 6, 7]
>>> numbers[3:3] = 'four'   # 這裡需要註意的是,插入一個字元串類型的元素到列表中需要寫成只有該元素的列表,否則會出現多個元素
>>> numbers
[1, 2, 3, 'f', 'o', 'u', 'r', 5, 6, 7]
>>> numbers = [1, 2, 3, 5, 6, 7]
>>> numbers[3:3] = ['four']  # 於extend一樣,可以通過切片的方式實現相同的效果,但是可讀性依舊不強  
>>> numbers
[1, 2, 3, 'four', 5, 6, 7]
>>>
  • pop()

方法pop從列表中刪除一個元素(預設為最後一個元素),並返回該元素。

>>> 
>>> x = [1, 2, 3]
>>> x.pop() 
3
>>> x
[1, 2]
>>> y = x.pop(0)
>>> y
1
>>> x
[2]
>>>
>> x = [1, 2, 3]
>>> x.append(x.pop())
>>> x
[1, 2, 3]
>>>
>>> x = [1, 2, 3]
>>> x.insert(0, x.pop())
>>> x
[3, 1, 2]
>>>
>>> x = [1, 2, 3]  
>>> x.append(x.pop(0))
>>> x
[2, 3, 1]
>>>

註意,pop是唯一既可以修改列表又返回一個非None值的列表方法。

使用pop可實現一種常用的數據結構——棧(stack)。棧就像一疊盤子,可以在上面添加盤子,還可以從上面取走盤子。最後加入的盤子最先取走,即後進先出(LIFO=last in first out)
還有一種與棧對應的數據結構稱為——堆(heap)。堆的概念正好與棧相反,最先放入的盤子最先出去,即先進先出(FIFO=first in first out)隊列是一種堆。

push和pop是大家普遍接受的兩種棧操作(加入和取走)的名稱。Python中沒有提供push,可以使用append代替。方法pop和append的效果正好相反。
要創建先進先出(FIFO)的隊列,可以使用insert(0,...)代替append。另外也可以使用append,用pop(0)代替pop()。或使用collections模塊中的deque。

  • remove()

方法remove用於刪除第一個為指定元素的值。

>>> 
>>> x = ['to', 'be', 'or', 'not', 'to', 'be']
>>> x.remove('be')
>>> x
['to', 'or', 'not', 'to', 'be']
>>> x.remove('bee') 
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ValueError: list.remove(x): x not in list
>>>

remove無法刪除列表中不存在的元素。
remove是就地修改列表且不返回值的方法之一,不同於pop,它修改列表但是不返回任何值。

  • reverse()

方法reverse按相反的順序排列列表中的元素。

>>> 
>>> x = [1, 2, 3] 
>>> x.reverse()
>>> x
[3, 2, 1]
>>>
>>> x = [1, 2, 3]
>>> y = reversed(x)
>>> y
<list_reverseiterator object at 0x015514D8>
>>> list(y) 
[3, 2, 1]
>>>

註意reverse修改列表,但是不返回任何值(與remove和sort等方法一樣)。

如果要按相反的順序迭代序列,可以使用函數reversed,這個函數返回的結果是一個迭代器。可以使用list轉換為列表。

  • sort()

方法sort用於對列表就地排序,會對原來的列表進行修改,而不是返回排序後的列表副本。

>>> 
>>> x = [4, 5, 6, 1, 9 ,0 ,3] 
>>> x.sort()
>>> x
[0, 1, 3, 4, 5, 6, 9]
>>>
>>> x = [4, 5, 6, 1, 9 ,0 ,3]
>>> y = x.sort() # 由於sort修改x且不返回任何值,最終的結果是x經過排序的,所以y是None
>>> print(y) 
None
>>>
>>> x = [4, 5, 6, 1, 9 ,0 ,3]
>>> y = x.copy()
>>> y.sort()
>>> x
[4, 5, 6, 1, 9, 0, 3]
>>> y
[0, 1, 3, 4, 5, 6, 9]
>>>
>>> x = [4, 5, 6, 1, 9 ,0 ,3]
>>> y = sorted(x) # 函數sorted()返回排序後的列表
>>> x
[4, 5, 6, 1, 9, 0, 3]
>>> y
[0, 1, 3, 4, 5, 6, 9]
>>>
>>> sorted('Python')  
['P', 'h', 'n', 'o', 't', 'y']
>>>
>>> 
>>> x = [4, 5, 6, 1, 9 ,0 ,3]
>>> x.sort(reverse=True)  # sort支持可選參數reverse:Ture or False
>>> 
>>> x
[9, 6, 5, 4, 3, 1, 0]
>>> 
>>> x = [4, 5, 6, 1, 9 ,0 ,3]
>>> x.sort(reverse=False)  # sort支持可選參數reverse:Ture or False  
>>> x
[0, 1, 3, 4, 5, 6, 9]
>>>
>>> x = ['aardvark', 'abalone', 'acme', 'add', 'aerate']
>>> x.sort(key=len)  # sort支持可選參數key
>>> x
['add', 'acme', 'aerate', 'abalone', 'aardvark']
>>>

函數sorted()的返回值是排序後的列表,註意sort()無返回值。sorted可以用於任何序列,返回的總是一個倒置的列表。

方法sort接受兩個可以選參數:key和reverse,稱為關鍵字參數。同樣sorted也支持可選參數key和reverse,此處可以將key設置為一個函數很管用。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 獲取微信昵稱、頭像、OpenID 微信公眾號服務號的網頁授權功能開發,主要是通過js跳轉到一個微信提供的url 然後微信會彈出獲取昵稱頭像的按鈕 允許獲取後,會回跳到我們的網址上,並且帶著一個code參數 我們拿到code參數,調用介面獲取到獲取到昵稱頭像、以及openid。這樣就拿到了微信客戶的主 ...
  • 函數模板 模板的意義:對類型也參數化 int sum1(int a,int b){return a+b;} double sum2(double a ,double b){return a+b;} 幾個概念 函數模板 模板的實例化 模板函數 模板類型參數 模板非類型參數 模板實參推演 模板的特例化 ...
  • # 1.公共操作 # del 刪除 刪除變數或指定容器內數據 變數,容器裡面的值 # + 將兩個相同類型序列進行連接 字元串,列表,元組 print('1.公共操作') print('a' + 'b') print(['a'] + ['b']) print(('a',)+('b',)) # 元組,要 ...
  • 小伙伴們曾經可能都經歷過整天寫著CURD的業務,都沒寫過一些組件相關的東西,這篇文章記錄一下SpringBoot如何自定義一個Starter。 原理和理論就不用多說了,可以在網上找到很多關於該方面的資料,這裡主要分享如何自定義。 原文鏈接:SpringBoot怎麼自定義一個Starter ?一隻小C ...
  • 使用 .editorconfig 統一規範 Visual Studio 編碼格式,使用 /utf-8 編譯選項指定源碼文件解碼格式,使得整個團隊文件編碼、代碼格式保持一致。 ...
  • 類的生命周期 首先我們先看類的生命周期 類的載入過程包含了載入、驗證、準備、解析、初始這五個階段,其中除瞭解析階段其他四個階段的發生順序都是確定的,因為解析階段在某些情況下會在初始階段之後開始,同時這些階段都是按順序開始的不是按順序進行或結束,因為這些階段通常都是互相交叉的混合進行。以下為類的生命周 ...
  • 引入課程和Maven 1.Maven maven中央倉庫:Maven Repository: Search/Browse/Explore (mvnrepository.com) maven倉庫是國外的一個網站,由於網路問題,我們也常使用maven倉庫的鏡像 maven的原理和java程式操作資料庫, ...
  • hello,大家好呀,我是既寫 Java 又寫 Go 的小樓,在寫 Go 的過程中經常對比這兩種語言的特性,踩了不少坑,也發現了不少有意思的地方,今天就來聊聊 Go 自帶的 HttpClient 的超時機制。 Java HttpClient 超時底層原理 在介紹 Go 的 HttpClient 超時 ...
一周排行
    -Advertisement-
    Play Games
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...
  • 目錄前言PostgreSql安裝測試額外Nuget安裝Person.cs模擬運行Navicate連postgresql解決方案Garnet為什麼要選擇Garnet而不是RedisRedis不再開源Windows版的Redis是由微軟維護的Windows Redis版本老舊,後續可能不再更新Garne ...
  • C#TMS系統代碼-聯表報表學習 領導被裁了之後很快就有人上任了,幾乎是無縫銜接,很難讓我不想到這早就決定好了。我的職責沒有任何變化。感受下來這個系統封裝程度很高,我只要會調用方法就行。這個系統交付之後不會有太多問題,更多應該是做小需求,有大的開發任務應該也是第二期的事,嗯?怎麼感覺我變成運維了?而 ...
  • 我在隨筆《EAV模型(實體-屬性-值)的設計和低代碼的處理方案(1)》中介紹了一些基本的EAV模型設計知識和基於Winform場景下低代碼(或者說無代碼)的一些實現思路,在本篇隨筆中,我們來分析一下這種針對通用業務,且只需定義就能構建業務模塊存儲和界面的解決方案,其中的數據查詢處理的操作。 ...
  • 對某個遠程伺服器啟用和設置NTP服務(Windows系統) 打開註冊表 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\W32Time\TimeProviders\NtpServer 將 Enabled 的值設置為 1,這將啟用NTP伺服器功 ...
  • title: Django信號與擴展:深入理解與實踐 date: 2024/5/15 22:40:52 updated: 2024/5/15 22:40:52 categories: 後端開發 tags: Django 信號 松耦合 觀察者 擴展 安全 性能 第一部分:Django信號基礎 Djan ...
  • 使用xadmin2遇到的問題&解決 環境配置: 使用的模塊版本: 關聯的包 Django 3.2.15 mysqlclient 2.2.4 xadmin 2.0.1 django-crispy-forms >= 1.6.0 django-import-export >= 0.5.1 django-r ...
  • 今天我打算整點兒不一樣的內容,通過之前學習的TransformerMap和LazyMap鏈,想搞點不一樣的,所以我關註了另外一條鏈DefaultedMap鏈,主要調用鏈為: 調用鏈詳細描述: ObjectInputStream.readObject() DefaultedMap.readObject ...
  • 後端應用級開發者該如何擁抱 AI GC?就是在這樣的一個大的浪潮下,我們的傳統的應用級開發者。我們該如何選擇職業或者是如何去快速轉型,跟上這樣的一個行業的一個浪潮? 0 AI金字塔模型 越往上它的整個難度就是職業機會也好,或者說是整個的這個運作也好,它的難度會越大,然後越往下機會就會越多,所以這是一 ...
  • @Autowired是Spring框架提供的註解,@Resource是Java EE 5規範提供的註解。 @Autowired預設按照類型自動裝配,而@Resource預設按照名稱自動裝配。 @Autowired支持@Qualifier註解來指定裝配哪一個具有相同類型的bean,而@Resourc... ...