網站首頁 編程語言 正文
在上一期python numpy 模塊中對概述介紹了numpy 模塊安裝、使用方法、特點等入門知識。
- numpy 模塊是一個開源的第三方Python庫,常用于科學和工程領域,是科學Python和PyData 生態系統的核心。
- numpy 模塊易學易用的特點,基本上覆蓋了初學者到先進科學研究員的所有人群。
- numpy 模塊除了在matplotlib上應用,它還在
Pandas
、Scipy
、scikit-learn
等科學Python中。 - numpy 模塊也包含多維數組和矩陣數據結構,它專門提供了具有n維數組對象的
ndarray
,以及對其進行有效操作的方法。 - numpy 模塊也可用于對數組執行各種數學運算,提供高級數學函數庫,以及數組和矩陣的操作。
眾所周知,numpy 模塊中數組對象是其核心功能,我們本期重點來學習numpy 數組相關內容,
1. 什么是 ndarray?
ndarray 概念
數組是numpy 模塊核心數據結構。數組是值的網絡,它的內部包含有原始數據、如何定義元素以及如何解釋元素的信息。我們可以使用各種方式索引元素網格。
ndarray 是 numpy 模塊中定義 n維數組類型。ndarray 可以描述同種類型project的集合。
- 同種數據類型:numpy 數組中的所有元素都是同種類類型,如int32,float64等
- 同大小內存空間:每個project占用相同大小內存塊
- 同方式解釋:每個project由object數據類型指定,,其中一個與每個數組相關聯
- 可以N個整數對project進行索引
ndarray 內部關系
從數組中我們可以提取python對象表示的如索引是numpy 內置數組標量類型之一,我們可以通過使用數組標量來輕松操作復雜的數據排列。
通過以上ndarray 內部結構,我們可以看到 ndarray
主要由 dtype
、shape
、stride
組成
- ndarray 指向內存映射地址的指針-data對象
- ndarray 元素解釋形象-dtype對象
- ndarray 每個維度的元素之間的間隔-strides對象(tuple)
- ndarray 對每個維度的數量和大小的描述-shape對象(tuple)
以上四個python
對象就可以在ndarray 中通過索引的方式找到指定位置的數據。
同時我們也調用np.array().flags
獲取字節序、讀寫權限等信息,可知ndarray
底層是C和Fortran 實現的。
? C_CONTIGUOUS : True ? F_CONTIGUOUS : False ? OWNDATA : True ? WRITEABLE : True ? ALIGNED : True ? WRITEBACKIFCOPY : False ? UPDATEIFCOPY : False
2. ndarray 內存結構
ndarray 內存結構
我們通過numpy.array
方法創建一個2維數組
numpy.array(object, dtype = None, copy = True, order = None, subok = False, ndmin = 0)
import numpy as np a = np.array([[1,2],[4,5],[7,8]]) print("dim:",a.ndim) print("strides:",a.strides) print("dtype:",a.dtype) print("data:",a.data) print("shape:",a.shape) print(a)
通過array
對象調用ndarray
標量對象,可以獲知ndarray
維度大小、元素類型、間隔等信息
通過上述圖,我們可以知道 ndarray 內存主要劃分為兩部分:
- raw data: 計算機一段連續的block,存儲在C或者Fortran中的數組
- metdata:有關原始數組數據的信息
3. ndarray vs list
ndarray 特點
-
ndarray
要求所有數據都是同種類型的 - 每個數據占用空間一樣
- 數組中存儲的數據是一段連續的空間
list 特點
- 可以容納不同數據類型
- list 中只存放對象的引用,再通過引用找到具體的對象
- 對象的物理地址并不是連續的
?
所以,綜上所述,ndarray
查找數據運行效率比list快,同時ndarray
存儲的數據是連續的一段空間,對比list 對象物理地址分散的,ndarray 比 list 更省空間。
總結:
本期對numpy 模塊核心之一的ndarray 數組對象內存原理、與python list對比等知識學習。
ndarray 里的所有的project元素都是同類型數據,并且存儲空間是連續的。
不管查找數據,還是存儲數據,數據計算等功能,都明顯優于Python list。
原文鏈接:https://juejin.cn/post/7054576233807364132
相關推薦
- 2022-04-23 Python繪制燈籠的示例代碼_python
- 2022-03-30 C語言入門之淺談數據類型和變量常量_C 語言
- 2022-04-03 帶你理解C語言中的漢諾塔公式_C 語言
- 2022-06-06 數據分析數據庫ClickHouse在大數據領域應用實踐_數據庫其它
- 2022-03-26 C++成員解除引用運算符的示例詳解_C 語言
- 2022-10-22 React拖拽調整大小的組件_React
- 2022-01-29 執行composer安裝命令報錯處理
- 2022-10-05 C語言二叉樹的概念結構詳解_C 語言
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支