CrazyWing:Python自動化運維開發實戰 9、Python數據類型之列表

導語

序列:
序列是Python中最基本的數據結構。序列中的每一個元素都分配一個數字 - 它的位置,或索引,第一個索引是0,第二個索引是1,依此類推,Python已經內置肯定序列的長度以及肯定最大和最小的元素的方法。Python有6個序列的內置類型,最多見的是列表和元組。python

序列操做包括:
索引,切片,加,乘,檢查成員數據結構

列表:

列表是序列的一種,屬最經常使用的Python數據類型,它支持字符,數字,字符串甚至能夠包含列表(嵌套),他的數據項不須要具備相同的類型

建立列表:

以逗號分隔的不一樣的數據項使用方括號括起來便可。
例如:app

list1 = ['physics', 'chemistry', 1997, 2000];
list2 = [1, 2, 3, 4, 5 ];
list3 = ["a", "b", "c", "d"];
list4 = []       #建立空列表
list5 = list()  #建立空列表

列表截取:

語法:變量[頭下標:尾下標]
從左到右索引默認0開始的,從右到左索引默認-1開始,下標能夠爲空,表示取到頭或尾。
跟字符串的截取同樣,這裏再也不詳述
例1:
#!/usr/bin/python
list1 = ['physics', 'chemistry', 1997, 2000];
list2 = [1, 2, 3, 4, 5, 6, 7 ];ide

print "list1[0]: ", list1[0]
print "list2[1:5]: ", list2[1:5]

以上實例輸出結果:
list1[0]:  physics
list2[1:5]:  [2, 3, 4, 5]

例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]

批量替換:ui

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]

另類刪除:spa

In [7]: a=[12,3,4,3]
In [8]: a[2:]=[]
In [9]: a
Out[9]: [12, 3]

列表中嵌套列表: code

>>> 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']
相關文章
相關標籤/搜索