python 陣列相關知識總結(未完)
變數的深淺賦值(to be continued)
1、Numpy是什麼
很簡單,Numpy是Python的一個科學計算的庫,提供了矩陣運算的功能,其一般與Scipy、matplotlib一起使用。其實,list已經提供了類似於矩陣的表示形式,不過numpy為我們提供了更多的函式。如果接觸過matlab、scilab,那麼numpy很好入手。 在以下的程式碼示例中,總是先匯入了numpy:
>>> import numpy as np
>>> print np.version.version
1.6.2
2、多維陣列
多維陣列的型別是:numpy.ndarray。
使用numpy.array方法
以list或tuple變數為引數產生一維陣列:
[1 2 3 4]
>>> print np.array((1.2,2,3,4))
[ 1.2 2. 3. 4. ]
>>> print type(np.array((1.2,2,3,4)))
<type 'numpy.ndarray'>
以list或tuple變數為元素產生二維陣列:
複製程式碼程式碼如下:
>>> print np.array([[1,2],[3,4]])
[[1 2]
[3 4]]
生成陣列的時候,可以指定資料型別,例如numpy.int32, numpy.int16, and numpy.float64等:
複製程式碼程式碼如下:
>>> print np.array((1.2,2,3,4), dtype=np.int32)
[1 2 3 4]
使用numpy.arange方法
複製程式碼程式碼如下:
>>> print np.arange(15)
[ 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14]
>>> print type(np.arange(15))
<type 'numpy.ndarray'>
>>> print np.arange(15).reshape(3,5)
[[ 0 1 2 3 4]
[ 5 6 7 8 9]
[10 11 12 13 14]]
>>> print type(np.arange(15).reshape(3,5))
<type 'numpy.ndarray'>
使用numpy.linspace方法
例如,在從1到3中產生9個數:
>>> print np.linspace(1,3,9)
[ 1. 1.25 1.5 1.75 2. 2.25 2.5 2.75 3. ]
使用numpy.zeros,numpy.ones,numpy.eye等方法可以構造特定的矩陣
例如:
>>> print np.zeros((3,4))
[[ 0. 0. 0. 0.]
[ 0. 0. 0. 0.]
[ 0. 0. 0. 0.]]
>>> print np.ones((3,4))
[[ 1. 1. 1. 1.]
[ 1. 1. 1. 1.]
[ 1. 1. 1. 1.]]
>>> print np.eye(3)
[[ 1. 0. 0.]
[ 0. 1. 0.]
[ 0. 0. 1.]]
建立一個三維陣列:
複製程式碼程式碼如下:
>>> print np.zeros((2,2,2))
[[[ 0. 0.]
[ 0. 0.]]
[[ 0. 0.]
[ 0. 0.]]]
獲取陣列的屬性:
複製程式碼程式碼如下:
>>> a = np.zeros((2,2,2))
>>> print a.ndim #陣列的維數
3
>>> print a.shape #陣列每一維的大小
(2, 2, 2)
>>> print a.size #陣列的元素數
8
>>> print a.dtype #元素型別
float64
>>> print a.itemsize #每個元素所佔的位元組數
8
陣列索引,切片,賦值
示例:
>>> a = np.array( [[2,3,4],[5,6,7]] )
>>> print a
[[2 3 4]
[5 6 7]]
>>> print a[1,2]
7
>>> print a[1,:]
[5 6 7]
>>> print a[1,1:2]
[6]
>>> a[1,:] = [8,9,10]
>>> print a
[[ 2 3 4]
[ 8 9 10]]
使用for操作元素
複製程式碼程式碼如下:
>>> for x in np.linspace(1,3,3):
... print x
...
1.0
2.0
3.0
基本的陣列運算
先構造陣列a、b:
>>> a = np.ones((2,2))
>>> b = np.eye(2)
>>> print a
[[ 1. 1.]
[ 1. 1.]]
>>> print b
[[ 1. 0.]
[ 0. 1.]]
陣列的加減乘除:
複製程式碼程式碼如下:
>>> print a > 2
[[False False]
[False False]]
>>> print a+b
[[ 2. 1.]
[ 1. 2.]]
>>> print a-b
[[ 0. 1.]
[ 1. 0.]]
>>> print b*2
[[ 2. 0.]
[ 0. 2.]]
>>> print (a*2)*(b*2)
[[ 4. 0.]
[ 0. 4.]]
>>> print b/(a*2)
[[ 0.5 0. ]
[ 0. 0.5]]
>>> print (a*2)**4
[[ 16. 16.]
[ 16. 16.]]
使用陣列物件自帶的方法:
>>> a.sum()
4.0
>>> a.sum(axis=0) #計算每一列(二維陣列中類似於矩陣的列)的和
array([ 2., 2.])
>>> a.min()
1.0
>>> a.max()
1.0
使用numpy下的方法:
>>> np.sin(a)
array([[ 0.84147098, 0.84147098],
[ 0.84147098, 0.84147098]])
>>> np.max(a)
1.0
>>> np.floor(a)
array([[ 1., 1.],
[ 1., 1.]])
>>> np.exp(a)
array([[ 2.71828183, 2.71828183],
[ 2.71828183, 2.71828183]])
>>> np.dot(a,a) ##矩陣乘法
array([[ 2., 2.],
[ 2., 2.]])
合併陣列
使用numpy下的vstack和hstack函式:
>>> a = np.ones((2,2))
>>> b = np.eye(2)
>>> print np.vstack((a,b))
[[ 1. 1.]
[ 1. 1.]
[ 1. 0.]
[ 0. 1.]]
>>> print np.hstack((a,b))
[[ 1. 1. 1. 0.]
[ 1. 1. 0. 1.]]
看一下這兩個函式有沒有涉及到淺拷貝這種問題:
>>> c = np.hstack((a,b))
>>> print c
[[ 1. 1. 1. 0.]
[ 1. 1. 0. 1.]]
>>> a[1,1] = 5
>>> b[1,1] = 5
>>> print c
[[ 1. 1. 1. 0.]
[ 1. 1. 0. 1.]]
可以看到,a、b中元素的改變並未影響c。
深拷貝陣列
陣列物件自帶了淺拷貝和深拷貝的方法,但是一般用深拷貝多一些:
>>> b = a
>>> b is a
True
>>> c = a.copy() #深拷貝
>>> c is a
False
基本的矩陣運算
轉置:
>>> a = np.array([[1,0],[2,3]])
>>> print a
[[1 0]
[2 3]]
>>> print a.transpose()
[[1 2]
[0 3]]
跡:
複製程式碼程式碼如下: >>> print np.trace(a)
4
numpy.linalg模組中有很多關於矩陣運算的方法:
複製程式碼程式碼如下:
>>> import numpy.linalg as nplg
特徵值、特徵向量:
>>> print nplg.eig(a)
(array([ 3., 1.]), array([[ 0. , 0.70710678],
[ 1. , -0.70710678]]))
3、矩陣
numpy也可以構造矩陣物件,這裡不做討論。
python進階教程之迴圈相關函式range、enumerate、zip,pythonenumerate
在“迴圈”一節,我們已經討論了Python基本的迴圈語法。這一節,我們將接觸更加靈活的迴圈方式。
range()
在Python中,for迴圈後的in跟隨一個序列的話,迴圈每次使用的序列元素,而不是序列的下標。
之前我們已經使用過range()來控制for迴圈。現在,我們繼續開發range的功能,以實現下標對迴圈的控制:
S = 'abcdefghijk'
for i in range(0,len(S),2):
print S[i]
在該例子中,我們利用len()函式和range()函式,用i作為S序列的下標來控制迴圈。在range函式中,分別定義上限,下限和每次迴圈的步長。這就和C語言中的for迴圈相類似了。
enumerate()
利用enumerate()函式,可以在每次迴圈中同時得到下標和元素:
S = 'abcdefghijk'
for (index,char) in enumerate(S):
print index
print char
實際上,enumerate()在每次迴圈中,返回的是一個包含兩個元素的定值表(tuple),兩個元素分別賦予index和char
zip()
如果你多個等長的序列,然後想要每次迴圈時從各個序列分別取出一個元素,可以利用zip()方便地實現:
ta = [1,2,3]
tb = [9,8,7]
tc = ['a','b','c']
for (a,b,c) in zip(ta,tb,tc):
print(a,b,c)
每次迴圈時,從各個序列分別從左到右取出一個元素,合併成一個tuple,然後tuple的元素賦予給a,b,c
zip()函式的功能,就是從多個列表中,依次各取出一個元素。每次取出的(來自不同列表的)元素合成一個元組,合併成的元組放入zip()返回的列表中。zip()函式起到了聚合列表的功能。
我們可以分解聚合後的列表,如下:
複製程式碼 程式碼如下:ta = [1,2,3]
tb = [9,8,7]
# cluster
zipped = zip(ta,tb)
print(zipped)
# decompose
na, nb = zip(*zipped)
print(na, nb)
總結
range()
enumerate()
zip()
python中range函式中引數的問題
for i in range(-1,-len(s),-1): # -1至-(5-1),後面的-1表示反向取,那麼就是(-1,-2,-3,-4)
迴圈內:
print s(:-1) #從0取到最後一位,但不包含最後一位,abcd
print s(:-2) #從0取到倒數第二位,但不包含倒數第二位,abc
....
python for 迴圈
L = []
for i in range(5):
tmp = int(input("Enter an integer: "))
L.append(tmp)
print(sum(L))