1、Python的數組分三種類型:
(1) list 普通的鏈表,初始化後可以通過特定方法動態增加元素。
定義方式:arr = [元素]
(2) Tuple 固定的數組,一旦定義後,其元素個數是不能再改變的。
定義方式:arr = (元素)
(2) Dictionary 詞典類型, 即是Hash數組。
定義方式:arr = {元素k:v}
2、下面具體說明這些數組的使用方法和技巧:
(1) list 鏈表數組
a、定義時初始化
a = [1,2,[1,2,3]]
b、定義時不初始化
一維數組:
arr = []
多維陣列:
arr = [i for i in range(10), 1,[]] #注意, i for in xx 這個必須放在第一個位置,否則要先定義i,
如:
arr = [i for i in range(5), j for j in range(5), []]
這是錯誤的
i = 0
j = 0
arr = [i for i in range(5), j for j in range(5), []]
這是正確的
c、del 語句 和 : 的用法
可以用 start : end 表示數組裡的一個區間 ( i >= start and i < end)
del 刪除數組裡的指定元素
如: del arr[0]
del arr[0, 2]
newarr = arr[0, 2]
d、遍曆數組:
for k, v in enumerate(arr):
print k, v
e、增加元素:
一維
arr.append('aaa')
二維
arr[0].append('aaa')
如果要在任意位置插入用 arr.insert(n, 值)
此外還有一種特殊的用法是:
arr += [數組元素]
在不指定下標的情況下,是允許用 += 增加數組元素的。
(2) Tuple 固定數組
Tuple 是不可變 list,一旦建立了一個 tuple 就不能以任何方式改變它。
下面拿具體樣本說明:
>>> t = ("a", "b", "c", "d", "e") #[1] 用小括弧包圍來定義
>>> t
('a', 'b', 'c', 'd', 'e')
>>> t[0] #[2] 直接列出某下標的元素
'a'
>>> t[-1] #[3] 負數表示,從後面倒數的索引 -1 為倒數第一個, 0是順數第一個
'example'
>>> t[1:3] #[4] 這裡 1:3 是 i>=1 and i<3 的區間
('b', 'mpilgrim')
Tuple 沒有的方法:
[1] 不能向 tuple 增加元素,沒有 append 、 extend 、insert 等方法。
[2] 不能從 tuple 刪除元素,沒有 remove 或 pop 方法。
[3] 不能在 tuple 中尋找元素,沒有 index 方法(index是尋找而不是索引,索引直接用下標即可,如:t[0])。
使用 tuple 的好處:
* Tuple 比 list 操作速度快。如果您定義了一個值的常量集, 並且唯一要用它做的是不斷地遍曆它, 請使用 tuple 代替 list。
* 如果對不需要修改的資料進行 “防寫保護”, 可以使代碼更安全。使用 tuple 而不是 list 如同擁有一個隱含的 assert 語句, 說明這一資料是常量。如果必須要改變這些值, 則需要執行 tuple 到 list 的轉換 (需要使用一個特殊的函數)。
* 還記得我說過 dictionary keys 可以是字串, 整數和 “其它幾種類型”嗎? Tuples 就是這些類型之一。 Tuples 可以在 dictionary 中被用做 key, 但是 list 不行。實際上, 事情要比這更複雜。Dictionary key 必須是不可變的。Tuple 本身是不可改變的, 但是如果您有一個 list 的 tuple, 那就認為是可變的了, 用做 dictionary key 就是不安全的。只有字串, 整數或其它對 dictionary 安全的 tuple 才可以用作
dictionary key。
Tuple 可以轉換成 list, 反之亦然。
轉換方式為:
t = list( t )
反之:
arr = tuple( arr )
(2) Dictionary (雜湊數組)詞典數組
#Dictionary 的用法比較簡單,它可以儲存任意值,並允許是不同類型的值,下面執行個體來說明:
#下面例子中 a 是整數, b 是字串, c 是數組,這個例子充分說明雜湊數組的適用性。
dict_arr = {'a': 100, 'b':'boy', 'c':['o', 'p', 'q']}
#可以直接增加一個元素,如果同名,則會改變原來的key的元素的值
dict_arr['d'] = 'dog'
#輸出所有的key
print dict_arr.keys()
#輸出所有的value
print dict_arr.values()
#遍曆數組
import types
for k in dict_arr:
v = dict_arr.get(k)
if type(v) is types.ListType: #如果資料是list類型,繼續遍曆
print k, '---'
for kk, vv in enumerate(v):
print kk, vv
print '---'
else:
print dict_arr.get(k)