Numpy np.array()函數使用方法指南
1、Numpy ndarray對象
numpy ndarray對象是一個n維數組對象,ndarray隻能存儲一系列相同元素。
#一維數組 [1,2,3,4] #shape(4,) #二維數組 [[1,2,3,4]] #shape(1,4) [[1,2,3,4], [5,6,7,8]] #shape(2,4) #三維數組 [ [[1,2,3],[4,5,6]], [[7,8,9],[10,11,12]] ] #shape(2,2,3)
2、創建numpy數組
numpy.array()使用說明:object是必須輸入的參數,其餘為可選參數。
import numpy as np np.array(object,dtype,copy=True,order,ndmin,subok=Fasle) # object: 一個數組序列,例如[1,2,3,4] # dtype: 更改數組內的數據類型 # copy: 數據源是ndarray時數組能否被復制,default=True # order: 選擇數組的內存佈局,C(行序列)|F(列序列)|A(默認) # ndmin: 數組維度 # subok: bool類型,True,使用object的內部數據類型;False,使用object的數組的數據類型,default=Fasle
創建存儲元素類型不同的數組:
#int型 import numpy as np a=np.array([1,2,3,4],dtype=int) #"dtype="可省略 print(a) a.dtype ''' 輸出: [1 2 3 4] dtype('int32') ''' #float型 b=np.array([1,2,3,4],dtype=float) print(b) b.dtype ''' 輸出: [1. 2. 3. 4.] dtype('float64') '''
創建生成器:
a=np.array([i*10 for i in range(10)]) print(a) b=np.array([i+2 for i in range(10)]) print(b) ''' 輸出: [ 0 10 20 30 40 50 60 70 80 90] [ 2 3 4 5 6 7 8 9 10 11] '''
當輸入的object元素有不同類型時,將保留存儲空間最大的類型:
x1=np.array([1,2,3,4,5.1]) print(x1) x2=np.array([1,2,3,'a']) print(x2) x3=np.array([1,2.1,'a']) print(x3) ''' 輸出: [1. 2. 3. 4. 5.1] ['1' '2' '3' 'a'] ['1' '2.1' 'a'] '''
當多維數組元素個數不一致時:
x=np.array([[1,2,3],[1,2,3,4],[1,2,3,4,5]],dtype=object) #存儲長度不一致序列時,應有“dtype=object”,否則會報錯 print(x) print(x.shape) print(x.ndim) #輸出數組的維度,2Darray強制轉換成1Darray ''' 輸出: [list([1, 2, 3]) list([1, 2, 3, 4]) list([1, 2, 3, 4, 5])] (3,) 1 '''
float強制轉化int(向下取整):
a=np.array([1,2,3.1],int) b=np.array([1,2,3.7],int) print(a) print(b) ''' 輸出: [1 2 3] [1 2 3] '''
用copy參數定義是否創建副本:
#默認copy=True情況下,復制創建x1的副本為x2 x1=np.array([1,2,3]) x2=np.array(x1) print('x1 ',id(x1),'x2',id(x2)) #更改x2的值,x1的值不會發生改變,反之,修改x1的值,x2也不會發生改變,因為二者地址不同 x2[2]=100 print('x1',x1) print('x2',x2) ''' 輸出: x1 2055556179312 x2 2055300844976 x1 x2地址不同 x1 [1 2 3] x2 [ 1 2 100] ''' #copy=Fasle情況下,復制創建x1的副本為x2 x1=np.array([1,2,3]) x2=np.array(x1,copy=False) print('x1 ',id(x1),'x2',id(x2)) #更改x2的值,x1的值會發生改變,且x1永遠等於x2,因為二者地址相同 x2[2]=100 print('x1',x1) print('x2',x2) ''' 輸出: x1 2055300125584 x2 2055300125584 x1 x2地址相同 x1 [ 1 2 100] x2 [ 1 2 100] ''' #另一種創建副本方法:copy() 這種方法更常用 x1=np.array([1,2,3]) x2=x1.copy() print('x1 ',id(x1),'x2',id(x2)) #更改x2的值,x1的值不會發生改變 x2[2]=100 print('x1',x1) print('x2',x2) ''' 輸出: x1 2055556233040 x2 2055556062160 x1 [1 2 3] x2 [ 1 2 100] '''
ps:如果直接用 x2=x1 的形式復制array,此時x1 x2 共用同一個地址
用ndmin改變數組維度(升維有效,降維無效):
a=np.array([1,2,3,4],ndmin=2) print('a ',a) b=np.array([[1,2],[1,2]],ndmin=3) print('b ',b) #2D降維成1D,但輸出結果仍為2D c=np.array([[1,2],[1,2]],ndmin=1) print('c ',c) ''' 輸出: a [[1 2 3 4]] b [[[1 2] [1 2]]] c [[1 2] [1 2]] '''
用subok參數(bool值)確定數據類型:
x1=np.mat([1,2,3]) a1=np.array(x1) #存儲為原類型 b1=np.array(x1,subok=True) #存儲為數組類型 print('x1 ',type(x1),'a1 ',type(a1),'b1 ',type(b1)) #原始格式為list,無論subok為何值都轉換成數組類型 x2=[[1,2],[1,2],[1]] a2=np.array(x2,dtype=object) #存儲為原類型 b2=np.array(x2,dtype=object,subok=True) #存儲為數組類型 print('x2 ',type(x2),'a2 ',type(a2),'b2 ',type(b2)) ''' 輸出: x1 <class 'numpy.matrix'> a1 <class 'numpy.ndarray'> b1 <class 'numpy.matrix'> x2 <class 'list'> a2 <class 'numpy.ndarray'> b2 <class 'numpy.ndarray'> '''
總結
到此這篇關於Numpy np.array()函數使用方法指南的文章就介紹到這瞭,更多相關Numpy np.array()函數用法內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- 聊聊Numpy.array中[:]和[::]的區別在哪
- python數學建模之Numpy 應用介紹與Pandas學習
- Python Numpy中ndarray的常見操作
- 關於NumPy中asarray的用法及說明
- NumPy-ndarray 的數據類型用法說明