通常來說Python中任何值都是一個對象,因此任何類型(int、str、list…)都是一個類。而類就必然有它的方法或屬性,我們要記下這么多類的所有方法顯然是不可能的,對此本文介紹兩個小技巧:
dir() :內置函數,用來查詢一個類或者對象所有屬性,比如>>> dir(list)。
help() :內置函數,用來查詢具體的說明文檔,比如>>> help(int)。
在上一篇的Python3的基本數據類型中,我們初步了解了list列表,也介紹了列表是Python 中使用最頻繁的數據類型。本文將進一步深入學習列表的使用。
一、列表的方法:
list.append(x)
在列表的尾部添加一個項,等價于 a[len(a):] = [x]。
list.extend(L)
將給定的列表L接到當前列表后面,等價于 a[len(a):] = L。
list.insert(i, x)
在給定的位置 i 前插入項,例如:a.insert(0, x) 會在列表的頭部插入,而 a.insert(len(a), x) 則等價于 a.append(x)。
list.remove(x)
移除列表中第一個值為 x 的項,沒有的話會產生一個錯誤。
list.pop([i])
刪除列表給定位置的項,并返回它。如果沒指定索引,a.pop()移除并返回列表最后一項。(方括號表示可選)
list.clear()
刪除列表中的所有項,相當于 del a[:]。
list.index(x)
返回列表中第一個值為 x 的項的索引。如果沒有匹配的項, 則產生一個錯誤。
list.count(x)
返回列表中 x 出現的次數。
list.sort()
就地完成列表排序。
list.reverse()
就地完成列表項的翻轉。
list.copy()
返回列表的一個淺拷貝,相當于a[:]。
二、列表當棧
List的方法使得其可以很方便地作為一個棧來使用。我們知道,棧的特點是最后進入的元素最先出來(即后入先出),用append()方法進行壓棧,用不指定索引的pop()方法進行出棧。
示例代碼如下:
stack = []for x in range(1,6): stack.append(x) # 入棧 print('push', x, end=' ') print(stack)print('Now stack is', stack)while len(stack)>0: print('pop', stack.pop(), end=' ') # 出棧 print(stack)
三、列表當隊列
列表還可以當作隊列來使用,隊列的特性是第一個加入的元素第一個取出來(即先入先出)。然而,把列表當隊列使用效率并不高,因為從列表的尾部添加和彈出元素是很快的,而在列表的開頭插入或彈出是比較慢的(因為所有元素都得移動一個位置)。
要實現一個隊列, 使用標準庫的collections.deque, 它被設計成在兩端添加和彈出都很快。
示例代碼如下:
from collections import dequequeue = deque() # 創建空隊列for x in range(1,6): queue.append(x) # 入隊 print('push', x, end=' ') print(list(queue))print('Now queue is', list(queue))while len(queue)>0: print('pop', queue.popleft(), end=' ') # 出隊 print(list(queue))
新聞熱點
疑難解答