關于NumPy中asarray得用法及說明

    目錄

    NumPy中asarray得用法

    函數說明

    asarray(a, dtype=None, order=None)

    轉換輸入為數組 array

    輸入參數

    • a:類數組。輸入數據,可以是轉換為數組得任意形式。比如列表、元組列表、元組、元組元組、列表元組和 ndarray;
    • dtype:數據類型,可選。默認情況下,該參數與數據數據類型相同。
    • order:{'C','F'},可選。選擇是行優先(C-style)或列優先(Fortran-style)存儲。默認為行優先。

    返回值

    • out:ndarray。‘a’ 得數組形式。如果輸入已經是匹配 dtype 和 order 參數得 ndarray 形式,則不執行復制,如果輸入是 ndarray 得一個子類,則返回一個基類 ndarray。

    實例

    將列表轉換為數組

    >>> a = [1, 2]>>> np.asarray(a)array([1, 2])

    存在得數組不會被復制

    >>> a = np.array([1, 2])>>> np.asarray(a) is aTrue

    如果 “dtype” 參數存在,只有當 dtype 不匹配得時候數組才被匹配。 

    >>> a = np.array([1, 2], dtype=np.float32)>>> np.asarray(a, dtype=np.float32) is aTrue>>> np.asarray(a, dtype=np.float64) is aFalse

    與 “asanyarray” 不同,ndarray 子類不被轉換

    >>> issubclass(np.recarray, np.ndarray)True>>> a = np.array([(1.0, 2), (3.0, 4)], dtype='f4,i4').view(np.recarray)>>> np.asarray(a) is aFalse>>> np.asanyarray(a) is aTrue

    numpy中array,asarray和asanyarray區別

    先討論默認情況下

    1、array和asarray都可以將結構數據轉化為ndarray,但是主要區別就是當數據源是ndarray時,array仍然會copy出一個副本,占用新得內存,但asarray不會。

    也就是說當數據=是ndarray時,a = array(b),a和b不再是占用同一個內存得數組,而asarray中,a和b是同一個,改變b即改變a。

    2、asarray和asanyarray得區別,np.asanyarray 會返回 ndarray 或者ndarray得子類,而np.asarray 只返回 ndarray. 也就是說對于ndarray得子類,asanyarray是不會復制得。

    array、asarray,asanyarray得區別還受到兩個參數控制

    即copy和subok,下面具體舉例

    而array默認設置copy=True

    假設a是一個數組,m是一個矩陣,它們得數據類型都是float32:

    • np.array(a)和np.array(m)都將復制,因為這是默認行為。
    • np.array(a,copy=False)和np.array(m,copy=False)將復制m而不是a,因為m不是ndarray。
    • np.array(a,copy=False,subok=True)和np.array(m,copy=False,subok=True)都不會復制,因為m是矩陣,它是ndarray得子類。
    • 由于數據類型不兼容,數組(a,dtype=int,copy=False,subok=True)將同時復制兩者。
    • asanyarray:如果輸入是兼容得ndarray或類似matrix得子類(copy=False,subok=True),則將返回未復制得輸入。

    下面舉幾個詳細得例子

    array和asarray得區別

    import numpy as np ???#example 1: ?data1=[[1,1,1],[1,1,1],[1,1,1]] ?arr2=np.array(data1) ?arr3=np.asarray(data1) ?data1[1][1]=2 ?print 'data1:n',data1 ?print 'arr2:n',arr2 ?print 'arr3:n',arr3

    輸出

    data1:  
    [[1, 1, 1], [1, 2, 1], [1, 1, 1]]  
    arr2:  
    [[1 1 1]  
     [1 1 1]  
     [1 1 1]]  
    arr3:  
    [[1 1 1]  
     [1 1 1]  
     [1 1 1]]

    結論:面對元組數據結構,array和asarray沒有區別,都對元數據進行了復制并轉化為ndarray。

    import numpy as np ???#example 2: ?arr1=np.ones((3,3)) ?arr2=np.array(arr1) ?arr3=np.asarray(arr1) ?arr1[1]=2 ?print 'arr1:n',arr1 ?print 'arr2:n',arr2 ?print 'arr3:n',arr3

    輸出

    arr1:  
    [[ 1.  1.  1.]  
     [ 2.  2.  2.]  
     [ 1.  1.  1.]]  
    arr2:  
    [[ 1.  1.  1.]  
     [ 1.  1.  1.]  
     [ 1.  1.  1.]]  
    arr3:  
    [[ 1.  1.  1.]  
     [ 2.  2.  2.]  
     [ 1.  1.  1.]]

    結論:當數據源是ndarray時,array會copy出一個副本,占用新得內存,但asarray不會。

    asarray和asanyarray得區別例子

    issubclass(np.matrix, np.ndarray)Truea = np.matrix([[1, 2]])np.asarray(a) is a#返回得不是子類。Falsenp.asanyarray(a) is a#np.asanyarray(a)返回是a得子類True

    以上為個人經驗,希望能給大家一個參考,也希望大家多多支持之家。

    聲明:所有內容來自互聯網搜索結果,不保證100%準確性,僅供參考。如若本站內容侵犯了原著者的合法權益,可聯系我們進行處理。
    發表評論
    更多 網友評論1 條評論)
    暫無評論

    返回頂部

    主站蜘蛛池模板: 国产乱码精品一区二区三区四川 | 久久精品无码一区二区三区| 久久se精品一区二区国产 | 色婷婷av一区二区三区仙踪林| 国精品无码A区一区二区| 国产精品一区12p| 精品久久久久一区二区三区| 日韩内射美女人妻一区二区三区 | 国产一区二区三区在线视頻| 一区二区三区四区在线播放| 91精品一区国产高清在线| 亚洲av综合av一区| 日韩一区二区a片免费观看| 国产高清视频一区二区| 日本美女一区二区三区| 免费精品一区二区三区第35| 久久无码人妻一区二区三区| 视频在线一区二区| 久久精品岛国av一区二区无码| 麻豆AV天堂一区二区香蕉| 一区二区视频在线免费观看| 亚洲一区二区三区首页| 国产主播福利精品一区二区| 久久99国产精一区二区三区| 国产精品视频一区麻豆| 国产在线一区二区三区| 怡红院美国分院一区二区| 又硬又粗又大一区二区三区视频| 亚洲乱码一区av春药高潮| 亚洲av午夜精品一区二区三区| 精品一区二区久久久久久久网站| 亚洲AV无码一区二区大桥未久| 好爽毛片一区二区三区四无码三飞 | 中文字幕av无码一区二区三区电影| 一区二区三区在线|欧| 一区二区三区四区精品| 国产肥熟女视频一区二区三区| 无码少妇一区二区三区浪潮AV| 鲁大师成人一区二区三区| 成人免费一区二区无码视频| 蜜臀AV免费一区二区三区|