CrazyWing:Python自动化运维开发实战 九、Python数据类型之列表
導語
序列:
序列是Python中最基本的數據結構。序列中的每個元素都分配一個數字 - 它的位置,或索引,第一個索引是0,第二個索引是1,依此類推,Python已經內置確定序列的長度以及確定最大和最小的元素的方法。Python有6個序列的內置類型,最常見的是列表和元組。
序列操作包括:
索引,切片,加,乘,檢查成員
列表:
列表是序列的一種,屬最常用的Python數據類型,它支持字符,數字,字符串甚至可以包含列表(嵌套),他的數據項不需要具有相同的類型創建列表:
以逗號分隔的不同的數據項使用方括號括起來即可。
例如:
列表截取:
語法:變量[頭下標:尾下標]
從左到右索引默認0開始的,從右到左索引默認-1開始,下標可以為空,表示取到頭或尾。
跟字符串的截取一樣,這里不再詳述
例1:
#!/usr/bin/python
list1 = ['physics', 'chemistry', 1997, 2000];
list2 = [1, 2, 3, 4, 5, 6, 7 ];
例2:
L = ['spam', 'Spam', 'SPAM!']| L[2] | 'SPAM!' | 讀取列表中第三個元素 | | L[-2] | 'Spam' | 讀取列表中倒數第二個元素 | | L[1:] | ['Spam', 'SPAM!'] | 從第二個元素開始截取列表 |更新列表:
可以對列表的數據項進行修改或更新,也可以使用append()方法來添加列表項 例如: #!/usr/bin/python list = ['physics', 'chemistry', 1997, 2000]; print "Value available at index 2 : " print list[2] list[2] = 2001 #更新列表元素 print "New value available at index 2 : " print list[2]以上實例輸出結果: Value available at index 2 : 1997 New value available at index 2 : 2001刪除列表元素:
使用 del 語句來刪除列表的的元素 例: #!/usr/bin/python list1 = ['physics', 'chemistry', 1997, 2000] print list1 del list1[2] print "After deleting value at index 2 : " print list1以上實例輸出結果: ['physics', 'chemistry', 1997, 2000] After deleting value at index 2 : ['physics', 'chemistry', 2000]Python列表操作符:
+ 號用于組合列表 * 號用于重復列表 in 判斷元素是否在列表中 not in 例: | Python 表達式 | 結果 | 描述 | | [1, 2, 3] + [4, 5, 6] | [1, 2, 3, 4, 5, 6] | 組合 | | ['Hi!'] * 4 | ['Hi!', 'Hi!', 'Hi!', 'Hi!'] | 重復 | | 3 in [1, 2, 3] | True | 元素是否存在于列表中 | | for x in [1, 2, 3]: print x, | 1 2 3 | 迭代 |Python列表函數:
| 序號 | 函數 | | 1 | cmp(list1, list2) 比較兩個列表的元素 | | 2 | len(list) 列表元素個數 | | 3 | max(list) 返回列表元素最大值 | | 4 | min(list) 返回列表元素最小值 | | 5 | list(seq) 將序列轉換為列表 |Python列表方法:
| 序號 | 方法 | | 1 | list.append(obj) 在列表末尾添加新的對象 | | 2 | list.count(obj) 統計某個元素在列表中出現的次數 | | 3 | list.extend(seq) 在列表末尾一次性追加另一個序列中的多個值(用新列表擴展原來的列表) | | 4 | list.index(obj) 從列表中找出某個值第一個匹配項的索引位置 | | 5 | list.insert(index, obj) 將對象插入列表 | | 6 | list.pop(obj=list[-1]) 移除列表中的一個元素(默認最后一個元素),并且返回該元素的值 | | 7 | list.remove(obj) 移除列表中某個值的第一個匹配項 | | 8 | list.reverse() 反向列表中元素 | | 9 | list.sort([func]) 對原列表進行排序 |給列表插入數據的其他方法:
In [1]: a=[12,3,4,3] In [2]: a[2:2]=[8,8] In [3]: a Out[3]: [12, 3, 8, 8, 4, 3]批量替換:
In [4]: a=[12, 3, 8, 8, 4, 3] In [5]: a[2:]=[1,1,1,] In [6]: a Out[6]: [12, 3, 1, 1, 1]另類刪除:
In [7]: a=[12,3,4,3] In [8]: a[2:]=[] In [9]: a Out[9]: [12, 3]列表中嵌套列表:
>>> a=[1,2,['a','b']] >>> a [1, 2, ['a', 'b']] >>> a[2] ['a', 'b'] >>> a[2][0] 'a' >>> a[2][1] 'b'判斷一個對象是否是一個列表:
test=[1,2,3]
isinstance(test,list)
True
列表變量解包:
l1,l2 = [[1,'x','y'],[2,'z','r']]
print(l1)
[1, 'x', 'y']
print(l2)
[2, 'z', 'r']
查看系統內所有內置函數(BIF):isinstance就在里面
dir(builtins)
祛除列表中重復的元素
比較容易記憶的是用內置的set:
l1 = ['b','c','d','b','c','a','a'] l2 = list(set(l1)) print l2還有一種據說速度更快的,沒測試過兩者的速度差別
l1 = ['b','c','d','b','c','a','a'] l2 = {}.fromkeys(l1).keys() print l2這兩種都有個缺點,祛除重復元素后排序變了:
['a', 'c', 'b', 'd']如果想要保持他們原來的排序:
用list類的sort方法l1 = ['b','c','d','b','c','a','a']l2 = list(set(l1))l2.sort(key=l1.index)print l2也可以這樣寫:l1 = ['b','c','d','b','c','a','a']l2 = sorted(set(l1),key=l1.index)print l2也可以用遍歷:l1 = ['b','c','d','b','c','a','a']l2 = []for i in l1:if not i in l2:l2.append(i)print l2上面的代碼也可以這樣寫l1 = ['b','c','d','b','c','a','a']l2 = [][l2.append(i) for i in l1 if not i in l2]print l2這樣就可以保證排序不變了:['b', 'c', 'd', 'a']轉載于:https://blog.51cto.com/fklinux/2047390
總結
以上是生活随笔為你收集整理的CrazyWing:Python自动化运维开发实战 九、Python数据类型之列表的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: (译)理解 LSTM 网络 (Under
- 下一篇: EF架构~单表一对多集合的插入(树型结构