[Python][NumPy] N維數組類型 ndarray,形狀,資料結構,索引切片介紹

更新於 發佈於 閱讀時間約 8 分鐘

NumPy 提供了一種 N 維數組類型 ndarray(N-dimensional array) 它描述了相同類型的「數據類型」的集合。


ndarray 形狀大小

多維數組: ndarray 是一個 N 維數組,其中 N 可以是任意整數。一維數組是向量,二維數組是矩陣,以此類推

.shape

利用shape屬性查看,ndarray 在形狀描述了數組在每個維度上的大小。例如,形狀為 (2, 3) 的數組表示一個二維數組,其中維度為 2每行資料長度為3

import numpy as np

# 創建一個一維數組
arr1 = np.array([1, 2, 3, 4, 5])

# 創建一個二維數組
arr2 = np.array([[1, 2, 3],
[4, 5, 6]])

print("arr1.shape:", arr1.shape) # 輸出: (5,)
print("arr2.shape:", arr2.shape) # 輸出: (2, 3)

ndarray 數據類型

所有 ndarray 中的元素都需要具有相同的數據類型。這有助於提高數組的效率,因為 NumPy 可以針對特定數據類型進行優化

ndarray 中的元素具有特定的數據類型,如整數、浮點數、複數等。可以使用 dtype 屬性查看或設置數據類型。

.dtype

使用 dtype 屬性查看, ndarray 的資料型態。

import numpy as np

# 創建一個ndarray
arr = np.array([1, 2, 3, 4, 5])

# 創建一個包含整數和浮點數的ndarray
arr_mixed = np.array([1, 2.5, 3, 4.2, 5])

# 查看ndarray的資料型態
print("arr資料型態:", arr.dtype) #輸出 arr資料型態: int32
print("arr_mixed資料型態:", arr_mixed.dtype) #輸出 arr_mixed資料型態: float64

可以在創建 NumPy 數組的過程中使用 dtype 參數,明確指定數據類型

import numpy as np

# 使用 dtype 參數創建一個整數數組
arr_int = np.array([1, 2, 3, 4, 5], dtype=np.int32)

# 使用 dtype 參數創建一個浮點數數組
arr_float = np.array([1.1, 2.2, 3.3, 4.4, 5.5], dtype=np.float64)

# 使用 dtype 參數創建一個複數數組
arr_complex = np.array([1 + 2j, 3 + 4j, 5 + 6j], dtype=np.complex128)

# 查看數組的資料型態
print("整數數組的資料型態:", arr_int.dtype) #輸出 整數數組的資料型態: int32
print("浮點數數組的資料型態:", arr_float.dtype) #輸出 浮點數數組的資料型態: float64
print("複數數組的資料型態:", arr_complex.dtype) #輸出 複數數組的資料型態: complex128

分別使用 np.int32np.float64np.complex128 作為 dtype 參數來指定數據的類型。你可以根據需要選擇適當的 dtype,它包括整數、浮點數、複數等不同的類型。

這種明確指定數據類型的方式可以確保數據被正確地儲存處理


ndarray 索引切片

在 NumPy 中,你可以使用索引切片操作來訪問和修改 ndarray 中的元素

以下是一些基本的索引和切片操作:

索引操作:

一維數組:

索引的元素編號是從0開始。

import numpy as np

arr = np.array([1, 2, 3, 4, 5])

# 獲取第三個元素
print(arr[2]) # 輸出: 3

# 修改第一個元素
arr[0] = 10

print(arr) #輸出 [10 2 3 4 5]

多維數組:

import numpy as np

arr_2d = np.array([[1, 2, 3],
[4, 5, 6]])

# 獲取第一行第二列的元素
print(arr_2d[0, 1]) # 輸出: 2

# 修改第二行第三列的元素
arr_2d[1, 2] = 99

print(arr_2d)

#輸出
# [[ 1 2 3]
# [ 4 5 99]]

索引和切片操作在 NumPy 中是零起始的,這意味著第一個元素的索引是0


切片操作:

一維數組:

[:3] 表示選擇索引 0 到 2(不包括索引 3)的所有元素。

[-2:] 表示選擇倒數第二個元素到最後一個元素的所有元素。

import numpy as np

arr = np.array([1, 2, 3, 4, 5])

# 獲取前三個元素
print(arr[:3]) # 輸出: [1, 2, 3]

# 修改後兩個元素
arr[-2:] = 0

print(arr) #輸出 [1 2 3 0 0]

二維數組:

[0, :]

  • 這個切片表示選擇數組的第一行(索引為0的行)的所有列。
  • 0 表示選擇的是第一行,而 : 表示選擇整個第一行的所有列。

[:, 1]

  • 這個切片表示選擇數組的所有行的第二列(索引為1的列)。
  • : 表示選擇整個所有行,而 1 表示選擇第二列。

[1:, 1:]

  • 這個切片表示選擇數組的第二行及之後的所有行,以及第二列及之後的所有列。
  • 1: 表示選擇從索引1(第二行)開始的所有行,而 1: 表示選擇從索引1(第二列)開始的所有列。
import numpy as np

# 創建一個二維數組
arr_2d = np.array([[1, 2, 3],
[4, 5, 6],
[7, 8, 9]])

# 獲取第一行
first_row = arr_2d[0, :]
print("第一行:", first_row) # 輸出: [1, 2, 3]

# 獲取第二列
second_column = arr_2d[:, 1]
print("第二列:", second_column) # 輸出: [2, 5, 8]

# 使用切片獲取子矩陣
submatrix = arr_2d[1:, 1:]
print("子矩陣:")
print(submatrix)
# 輸出:
# [[5, 6],
# [8, 9]]

# 修改切片中的元素
arr_2d[1:, 1:] = 0
print("修改後的數組:")
print(arr_2d)
# 輸出:
# [[1, 2, 3],
# [4, 0, 0],
# [7, 0, 0]]

這些切片操作讓你能夠靈活地選擇 NumPy 數組中的不同子集,進行查看、修改或進行進一步的計算。


NumPy 中的 ndarray 之所以能夠提供高效的速度。

基於以下幾個關鍵:

  1. 底層實現: NumPy 的底層實現是用 C 語言編寫的。比 Python 更接近硬體,執行會更高效。
  2. 連續的內存布局: NumPy 的數組在記憶體中是連續存儲的,這使得對數組的訪問和操作更加高效。例如(一維的 NumPy 數組 [1, 2, 3, 4, 5],這五個元素將按照順序依次存儲在記憶體中的相鄰位置,可以直接訪問數組中的每一個元素,而不需要額外的計算或跳躍)
  3. 廣播(Broadcasting): NumPy 支持廣播操作,允許在不同形狀的數組之間進行操作。
  4. 向量化操作: NumPy 支持向量化操作,即對整個數組執行操作而無需使用顯式循環(for迴圈)。這使得在數組上進行數學和邏輯運算更加簡單,同時也更快速,因為底層操作可以在 C底層進行。
  5. 使用原生數據類型: NumPy 使用原生數據類型,而不是 Python 中的對象。這意味著數組中的元素在內存中是連續存儲的,且數據類型是已知的。相比於 Python 對象,這減少了內存開銷運行時開銷
  6. 優化的算法: NumPy 中的許多操作都經過了高度優化,例如矩陣乘法、FFT(快速傅立葉變換)等。底層的優化算法使得這些操作在處理大規模數據時能夠更加高效

參考文獻


avatar-img
128會員
216內容數
本業是影像辨識軟體開發,閒暇時間進修AI相關內容,將學習到的內容寫成文章分享。
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
螃蟹_crab的沙龍 的其他內容
NumPy在圖像處理、機器學習、數學和統計學等領域中被廣泛應用。 以下是一些常見的應用場景: 數據處理和分析: NumPy提供了高效的多維數組(nd array)和相應的操作函數,使得對大型數據集進行快速、有效的操作變得容易。
在程式開發中,協作合作專案時,利用type hint,可以快速知道函式輸入及輸出的資料型別,在後續的維護時也會更加方便及可讀。 Type hints 是Python 3.5 版本引入的功能,它允許在函數宣告中指定參數和傳回值的類型。Type hints 是一種可選的註解形式,不會影響程式碼的運行,
在現實生活中,充滿的警報及安全措施,總會設個安全線在那,若觸碰到底線時則會有警報響起。 在Python也有類似的作法,如果希望在某個條件達到時,就拉起警報不要讓程式繼續進行下去,就適合使用raise 這種機制讓開發者能夠在程序執行時檢測到不正確的條件,然後通過引發異常停止程序的執行或通知使用者。
在實務上,條碼槍傳送的資訊可能包含不可見字符或控制字符。這可能是因為條碼槍在傳送條碼數據時使用了一些特殊字符,這些字符在可見字符集合之外,例如 \x06 就是 ASCII 中的 "ACK" 控制字符。 本文將探討,如何查詢及處理這些特殊字符。
Python 提供了一系列內建函式,其中一部分涉及數學和數學操作。 以下是一些常用的內建函式和數學相關的函式: 基本數學運算: abs(x): 返回 x 的絕對值。 result = abs(-5) print(result) # 輸出: 5 max(iterable) 和 min(
在 Python 中,dir() 函式用於列舉對象的所有屬性和方法。這包括對象的內建屬性、方法以及自定義的屬性和方法。以下是一個簡單的示例: 列舉所有屬性與方法 class MyClass: def __init__(self): self.attribute1 = 42
NumPy在圖像處理、機器學習、數學和統計學等領域中被廣泛應用。 以下是一些常見的應用場景: 數據處理和分析: NumPy提供了高效的多維數組(nd array)和相應的操作函數,使得對大型數據集進行快速、有效的操作變得容易。
在程式開發中,協作合作專案時,利用type hint,可以快速知道函式輸入及輸出的資料型別,在後續的維護時也會更加方便及可讀。 Type hints 是Python 3.5 版本引入的功能,它允許在函數宣告中指定參數和傳回值的類型。Type hints 是一種可選的註解形式,不會影響程式碼的運行,
在現實生活中,充滿的警報及安全措施,總會設個安全線在那,若觸碰到底線時則會有警報響起。 在Python也有類似的作法,如果希望在某個條件達到時,就拉起警報不要讓程式繼續進行下去,就適合使用raise 這種機制讓開發者能夠在程序執行時檢測到不正確的條件,然後通過引發異常停止程序的執行或通知使用者。
在實務上,條碼槍傳送的資訊可能包含不可見字符或控制字符。這可能是因為條碼槍在傳送條碼數據時使用了一些特殊字符,這些字符在可見字符集合之外,例如 \x06 就是 ASCII 中的 "ACK" 控制字符。 本文將探討,如何查詢及處理這些特殊字符。
Python 提供了一系列內建函式,其中一部分涉及數學和數學操作。 以下是一些常用的內建函式和數學相關的函式: 基本數學運算: abs(x): 返回 x 的絕對值。 result = abs(-5) print(result) # 輸出: 5 max(iterable) 和 min(
在 Python 中,dir() 函式用於列舉對象的所有屬性和方法。這包括對象的內建屬性、方法以及自定義的屬性和方法。以下是一個簡單的示例: 列舉所有屬性與方法 class MyClass: def __init__(self): self.attribute1 = 42
你可能也想看
Google News 追蹤
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
本文介紹了在進行資料分析時,將類別欄位轉換為數值欄位的方法,包括Label Encoding、One-Hot Encoding、Binary Encoding、Target Encoding和Frequency Encoding。每種方法的應用範例、優缺點和適用場景都有詳細說明。
Thumbnail
pandas是用於資料操縱和分析的Python軟體庫。它建造在 NumPy 基礎上,並為操縱數值表格和時間序列,提供了資料結構和運算操作。 Pandas 的主要資料結構包含 Series 和 DataFrame 物件,由於 Pandas 本身基 Numpy 所以在使用大量資料運算時效能表現也優於原
Thumbnail
NumPy 是 Python 語言的一個擴充程式庫,支援高階大規模的多維陣列與矩陣運算的數學函式函式庫。 NumPy 2.0.0 是自 2006 年以來的第一個主要發行版本,此重要版本標誌著 NumPy 發展歷程中的一項重要里程碑,為使用者提供了豐富的增強功能和改進,並為未來的功能開發奠定了基礎。
前言 對標題上的這兩個項目有疑惑,不知道它們返回的資料的不同;查找資料後記錄下來,讓自己以後可以回來翻閱。 正文 numpy.ndarray.flatten:返回攤平的一維array,可參考NumPy: numpy.ndarray.flatten() function,有示意圖 te
Thumbnail
本文詳細介紹了Python中的各種資料型別,包括整數、字串、清單、元組、集合和字典,並提供了相關的操作範例。此外,還解釋了如何在Python中定義和操作變數,包括如何同時對多個變數進行賦值。
※ 常用arry型態的方法: 長度: length 查詢第N個元素: [] 查詢元素在第N個: indexOf( ) 判斷是否為array: isArray() 新增和刪除: push():新增後面的數值 unshift():新增前面的數值 pop():刪除後面的數值 sh
Thumbnail
題目會給定一個陣列nums和一個目標值goal。計算子陣列總和=goal的數目有多少。演算法包含前綴和和字典的技巧,時間複雜度為O(n),空間複雜度為O(n)。
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
本文介紹了在進行資料分析時,將類別欄位轉換為數值欄位的方法,包括Label Encoding、One-Hot Encoding、Binary Encoding、Target Encoding和Frequency Encoding。每種方法的應用範例、優缺點和適用場景都有詳細說明。
Thumbnail
pandas是用於資料操縱和分析的Python軟體庫。它建造在 NumPy 基礎上,並為操縱數值表格和時間序列,提供了資料結構和運算操作。 Pandas 的主要資料結構包含 Series 和 DataFrame 物件,由於 Pandas 本身基 Numpy 所以在使用大量資料運算時效能表現也優於原
Thumbnail
NumPy 是 Python 語言的一個擴充程式庫,支援高階大規模的多維陣列與矩陣運算的數學函式函式庫。 NumPy 2.0.0 是自 2006 年以來的第一個主要發行版本,此重要版本標誌著 NumPy 發展歷程中的一項重要里程碑,為使用者提供了豐富的增強功能和改進,並為未來的功能開發奠定了基礎。
前言 對標題上的這兩個項目有疑惑,不知道它們返回的資料的不同;查找資料後記錄下來,讓自己以後可以回來翻閱。 正文 numpy.ndarray.flatten:返回攤平的一維array,可參考NumPy: numpy.ndarray.flatten() function,有示意圖 te
Thumbnail
本文詳細介紹了Python中的各種資料型別,包括整數、字串、清單、元組、集合和字典,並提供了相關的操作範例。此外,還解釋了如何在Python中定義和操作變數,包括如何同時對多個變數進行賦值。
※ 常用arry型態的方法: 長度: length 查詢第N個元素: [] 查詢元素在第N個: indexOf( ) 判斷是否為array: isArray() 新增和刪除: push():新增後面的數值 unshift():新增前面的數值 pop():刪除後面的數值 sh
Thumbnail
題目會給定一個陣列nums和一個目標值goal。計算子陣列總和=goal的數目有多少。演算法包含前綴和和字典的技巧,時間複雜度為O(n),空間複雜度為O(n)。