欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

解決90%的常見問題的8個python NumPy函數(shù)

 更新時間:2023年06月01日 14:31:32   作者:alimejor  
這篇文章主要為大家介紹了解決90%的常見問題的8個python NumPy函數(shù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

NumPy

NumPy是一個用于科學計算和數(shù)據(jù)分析的Python庫,也是機器學習的支柱??梢哉fNumPy奠定了Python在機器學習中的地位。NumPy提供了一個強大的多維數(shù)組對象,以及廣泛的數(shù)學函數(shù),可以對大型數(shù)據(jù)集進行有效的操作。這里的“大”是指數(shù)百萬行。

Numpy快速而高效的原因是底層的C代碼,這比使用Python進行數(shù)組的操作要快上幾百倍,并且隨著數(shù)據(jù)量級的上升而上升。

本文中整理了一些可以解決常見問題的主要的NumPy函數(shù)。

1、創(chuàng)建數(shù)組

numpy.array:創(chuàng)建新的NumPy數(shù)組

# Create an array using np.array()
 arr = np.array([1, 2, 3, 4, 5])
 print(arr)
 Ouput: [1 2 3 4 5]

numpy.zeros:創(chuàng)建一個以零填充的數(shù)組。

# Create a 2-dimensional array of zeros
 arr = np.zeros((3, 4))
 [[0. 0. 0. 0.]
  [0. 0. 0. 0.]
  [0. 0. 0. 0.]]

類似的還有numpy.ones:創(chuàng)建一個都是1的數(shù)組 / numpy.empty:在不初始化數(shù)組元素的情況下創(chuàng)建數(shù)組。

使用numpy.random:生成隨機數(shù)組的函數(shù)。

# Generate a random integer between 0 and 9
 rand_int = np.random.randint(10)
 print(rand_int)

numpy.linspace:在指定范圍內生成均勻間隔的數(shù)字。

# Generate an array of 5 values from 0 to 10 (inclusive)
 arr = np.linspace(0, 10, 5)
 # Print the array
 print(arr)
 [ 0.   2.5  5.   7.5 10. ]

numpy.range:用間隔的值創(chuàng)建數(shù)組。

# Generate an array from 0 to 10 (exclusive) with step size 1
 arr = np.arange(0, 10, 2)
 # Print the array
 print(arr)
 [1 3 5 7 9]

2、查看數(shù)組信息

numpy.shape:返回一個表示數(shù)組形狀的元組。

numpy.ndim:返回數(shù)組的維度數(shù)。

numpy.dtype:獲取數(shù)組中元素的數(shù)據(jù)類型??梢允莍nt型,float型,bool型等等。

3、數(shù)組操作函數(shù)

numpy.reshape:改變數(shù)組的形狀。

# Create a 1-dimensional array
 arr = np.array([1, 2, 3, 4, 5, 6])
 # Reshape the array to a 2x3 matrix
 reshaped_arr = np.reshape(arr, (2, 3))
 [[1 2 3]
  [4 5 6]]

numpy.transpose:用于排列數(shù)組的維度。它返回一個軸調換后的新數(shù)組。

# Create a 2-dimensional array
 arr = np.array([[1, 2, 3],
                 [4, 5, 6]])
 # Transpose the array
 transposed_arr = np.transpose(arr)
 [[1 4]
  [2 5]
  [3 6]]

numpy.concatate:沿現(xiàn)有軸連接數(shù)組。

# Create two 1-dimensional arrays
 arr1 = np.array([1, 2, 3])
 arr2 = np.array([4, 5, 6])
 # Concatenate the arrays along axis 0 (default)
 concatenated_arr = np.concatenate((arr1, arr2))
 [1 2 3 4 5 6]

numpy.split:分割數(shù)據(jù),numpy.resize:改變數(shù)組的形狀和大小。

numpy.vstack:將多個數(shù)組垂直堆疊以創(chuàng)建一個新數(shù)組。

# Create two 1-dimensional arrays
 arr1 = np.array([1, 2, 3])
 arr2 = np.array([4, 5, 6])
 # Vertically stack the arrays
 stacked_arr = np.vstack((arr1, arr2))
 [[1 2 3]
  [4 5 6]]

numpy.hstack:與vstack類似,但是是水平堆疊數(shù)組。

4、數(shù)學函數(shù)

numpy.sum:計算數(shù)組元素的和。

numpy.mean:計算數(shù)組的算術平均值。

numpy.max:返回數(shù)組中的最大值。

numpy.min:返回數(shù)組中的最小值。

numpy.abs:計算元素的絕對值。

numpy.exp:計算所有元素的指數(shù)。

numpy.subtract: 對兩個數(shù)組的對應元素進行減法運算。

numpy.multiply: 對兩個數(shù)組的對應元素進行乘法運算。

numpy.divide: 對兩個數(shù)組的對應元素進行除法運算。

numpy.sin: 計算數(shù)組中每個元素的正弦值。

numpy.cos: 計算數(shù)組中每個元素的余弦值。

numpy.log: 計算數(shù)組中每個元素的自然對數(shù)(以e為底的對數(shù))。

5、統(tǒng)計函數(shù)

numpy.std:計算數(shù)組的標準差。

# Create a 1-dimensional array
 arr = np.array([1, 2, 3, 4, 5])
 # Compute the standard deviation of the array
 std = np.std(arr)
 1.4142135623730951

numpy.var:計算數(shù)組的方差。

numpy.histogram:計算一組數(shù)據(jù)的直方圖。

numpy.percentile:計算數(shù)組的第n個百分位數(shù)。它返回低于給定百分比的數(shù)據(jù)的值。

data = np.array([1, 2, 3, 4, 5, 6, 7, 8, 9, 10])
 # Calculate the 50th percentile (median) of the data
 median = np.percentile(data, 50)
 # Calculate the 25th and 75th percentiles (quartiles) of the data
 q1 = np.percentile(data, 25)
 q3 = np.percentile(data, 75)
 Median: 5.5
 Q1: 3.25
 Q3: 7.75

numpy.corcoef:計算兩個數(shù)組之間的相關系數(shù)。numpy.mean: 計算數(shù)組元素的平均值。numpy.median: 計算數(shù)組元素的中位數(shù)。

numpy.random.rand:在區(qū)間[0,1]內從均勻分布生成隨機數(shù)數(shù)組

# Generate a 1-dimensional array of random numbers
 random_array = np.random.rand(5)
 [0.35463311 0.67659889 0.5865293  0.77127035 0.13949178]

numpy.random.normal:從正態(tài)(高斯)分布生成隨機數(shù)

# Generate a random number from a normal distribution
 random_number = np.random.normal()
 -0.6532785285205665

6、線性代數(shù)函數(shù)

numpy.dot:計算兩個數(shù)組的點積。

# Create two arrays
 a = np.array([1, 2, 3])
 b = np.array([4, 5, 6])
 # Compute the dot product of the arrays
 dot_product = np.dot(a, b)
 32

numpy.linalg.inv:計算一個方陣的逆, numpy.linalg.eig:一個方陣的特征值和特征向量。numpy.linalg.solve:求解一個線性方程組。

7、排序函數(shù)

numpy.sort:沿指定軸返回數(shù)組的排序副本

# Create a 2D array
 arr = np.array([[3, 1, 5], [2, 4, 6]])
 # Sort the array along the second axis (columns)
 sorted_arr = np.sort(arr, axis=1)
 [[1 3 5]
  [2 4 6]]

numpy.argsort:返回按升序對數(shù)組排序的索引

# Create an array
 arr = np.array([3, 1, 5, 2, 4])
 # Get the indices that would sort the array
 sorted_indices = np.argsort(arr)
 [1 3 0 4 2]

8、其他一些高級的函數(shù)

numpy.unique:在數(shù)組中查找唯一的元素。

arr = np.array([2, 1, 3, 2, 1, 4, 5, 4])
 # Get the unique elements of the array
 unique_values = np.unique(arr)
 [1 2 3 4 5]

numpy.fft:傅里葉變換的函數(shù)。

numpy.ma:供對掩碼數(shù)組的支持。

  • numpy.ma.array:從現(xiàn)有的數(shù)組或序列創(chuàng)建一個掩碼數(shù)組。
  • numpy.ma.masked_array:從現(xiàn)有數(shù)組和掩碼中創(chuàng)建一個掩碼數(shù)組。
  • numpy.ma.mask:表示掩碼數(shù)組中的掩碼值。
  • numpy.ma.masked_invalid:屏蔽數(shù)組中無效的(NaN, Inf)元素。
  • numpy.ma.masked_greate, numpy.ma.masked_less:掩碼大于或小于給定值的元素。
arr = np.array([1, 2, 3, np.nan, 5])
 # Create a masked array by masking the invalid values
 masked_arr = ma.masked_invalid(arr)
 [1 2 3 5]

numpy.apply_along_axis:沿著數(shù)組的特定軸應用函數(shù)。

numpy.wheres:一個條件函數(shù),根據(jù)給定條件返回數(shù)組中滿足條件的元素的索引或值。

condition = np.array([True, False, True, False])
 # Create two arrays
 array_true = np.array([1, 2, 3, 4])
 array_false = np.array([5, 6, 7, 8])
 result = np.where(condition, array_true, array_false)
 [1 6 3 8]

以上就是Numpy最經(jīng)常被使用的函數(shù),希望對你有所幫助,更多關于python NumPy函數(shù)的資料請關注腳本之家其它相關文章!

相關文章

  • Python中元組的基礎介紹及常用操作總結

    Python中元組的基礎介紹及常用操作總結

    元組是一種不可變序列。元組變量的賦值要在定義時就進行,這就像C語言中的const變量或是C++的引用,定義時賦值之后就不允許有修改。元組存在的意義是:元組在映射中可以作為鍵使用,因為要保證鍵的不變性。元組作為很多內置函數(shù)和方法的返回值存在
    2021-09-09
  • Python連接DB2數(shù)據(jù)庫

    Python連接DB2數(shù)據(jù)庫

    DB2 是美國IBM公司開發(fā)的一套關系型數(shù)據(jù)庫管理系統(tǒng),它主要的運行環(huán)境為UNIX(包括IBM自家的AIX)、Linux、IBM i(舊稱OS/400)、z/OS,以及Windows服務器版本。今天我們來探討下如何使用Python連接DB2數(shù)據(jù)庫
    2016-08-08
  • 機器學習之數(shù)據(jù)清洗及六種缺值處理方式小結

    機器學習之數(shù)據(jù)清洗及六種缺值處理方式小結

    本文主要介紹了機器學習之數(shù)據(jù)清洗及六種缺值處理方式小結,包括刪除空行、填充平均值、中位數(shù)、眾數(shù)、線性插值和隨機森林填充,具有一定的參考價值,感興趣的可以了解一下
    2025-03-03
  • 淺析python表達式4+0.5值的數(shù)據(jù)類型

    淺析python表達式4+0.5值的數(shù)據(jù)類型

    在本篇文章里小編給大家整理的是一篇關于python表達式4+0.5值的數(shù)據(jù)類型的知識點內容,需要的的朋友們學習下。
    2020-02-02
  • pytest實現(xiàn)多種調用方式

    pytest實現(xiàn)多種調用方式

    pytest是一個非常成熟的全功能的Python測試框架,本文主要介紹了pytest多種調用方式,具有一定的參考價值,感興趣的可以了解一下
    2023-12-12
  • Python爬蟲實戰(zhàn)之12306搶票開源

    Python爬蟲實戰(zhàn)之12306搶票開源

    今天小編就為大家分享一篇關于Python爬蟲實戰(zhàn)之12306搶票開源,小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • python寫一個隨機點名軟件的實例

    python寫一個隨機點名軟件的實例

    今天小編就為大家分享一篇python寫一個隨機點名軟件的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • 利用Python中的pandas庫對cdn日志進行分析詳解

    利用Python中的pandas庫對cdn日志進行分析詳解

    這篇文章主要介紹了利用Python中的pandas庫進行cdn日志分析的相關資料,文中分享了pandas對cdn日志分析的完整示例代碼,然后詳細介紹了關于pandas庫的相關內容,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-03-03
  • python實現(xiàn)翻譯word表格小程序

    python實現(xiàn)翻譯word表格小程序

    這篇文章主要為大家詳細介紹了python翻譯word表格小程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • 如何利用Opencv實現(xiàn)圖像的加密解密

    如何利用Opencv實現(xiàn)圖像的加密解密

    一般情況下,圖像的加密和解密過程是通過按位異或運算實現(xiàn)的,下面這篇文章主要給大家介紹了關于如何利用Opencv實現(xiàn)圖像加密解密的相關資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2021-10-10

最新評論