$ c- G) e$ I! j0 ^
4. 创建随机数组 + U2 ]4 C% D% s * f% P% c; B+ Z% ?np.random 模块生成随机数组,更加方便,示例代码如下: & x! L3 l W6 k g2 p- l- _ , ^/ }3 B" [( I' K上面产生的数据是属于一个均匀分布。那么什么是均匀分布呢?在概率论和统计学中,均匀分布也叫矩形分布,它是对称概率分布,在相同长度间隔的分布概率是等可能的。 均匀分布由两个参数a和b定义,它们是数轴上的最小值和最大值,通常缩写为U(a,b)。9 u# `; j f2 w" f/ D4 e
; W% H0 b; v2 E) x8 ]7 \, p
正态分布?给定均值/标准差/维度的正态分布,示例代码如下: : s# v; i- N% I+ i, x `) Y V1 l/ h, M1 d( Z) B3 V& _9 @7 y
正态分布是一种概率分布。正态分布是具有两个参数μ和σ的连续型随机变量的分布,第一参数μ是服从正态分布的随机变量的均值,第二个参数σ是此随机变量的方差,所以正态分布记作N(μ,σ )。 G; l- F/ ~ `' W
' W5 ]+ F$ }5 @! o5 k& p' ^) ], n8 z生活、生产与科学实验中很多随机变量的概率分布都可以近似地用正态分布来描述。μ决定了其位置,其标准差σ。决定了分布的幅度。当μ = 0,σ = 1时的正态分布是标准正态分布。( @9 }+ j- |, s& C; W$ J/ n/ |2 K
& C1 A! k2 B8 s1 K/ L8 ~
标准差如何来?方差是在概率论和统计方差衡量一组数据时离散程度的度量。 , M5 I3 D* R) ]5 [% z, y ( ~: Z; u" X. p- K4 w其中M为平均值,n为数据总个数,s为标准差,s^2可以理解一个整体为方差。& h2 R: ~% i2 g1 n0 L: ?
7 h1 s) v: b1 b9 z0 ^% z
通过索引切片等获取数组中的值,一维数组示例代码如下: ( R- r# C* L0 r( x ; T# H- N2 x" W8 o ~8 [( k6 N. i二维数组示例代码如下:5 x: X- d$ |0 s4 C
) I! D4 f0 d2 r8 C3 m# |( ?; Y! v* q
三维数组示例代码如下:4 q& o( g) W) f& }" }
" s, E( d5 e6 X* X2 a5 E
6 G7 ^# B, q* S; V5 h% L
4. 数组形状与类型变化 2 I8 T. @3 K \) D, \; a3 c8 t$ C" h' c3 d3 {4 D
1. ndarray.reshape(shape[, order]) Returns an array containing the same data with a new shape. 示例代码如下:* v! y& B# c2 Q& Z. ^
, m2 u; C0 \! ~+ v) ]! s
2. ndarray.resize(new_shape[, refcheck]) Change shape and size of array in-place. 示例代码如下:- q% W% Y. b6 f2 L# f$ t2 T
: s' E7 o, b( Z3. 修改类型 ndarray.astype(type) 示例代码如下:) J$ n* {5 \ h
/ {1 `8 Y3 C2 i& V: k4. 修改小数位数 ndarray.round(arr, out) Return a with each element rounded to the given number of decimals. 示例代码如下:) Z2 k) v& t, ^; `% A
, |8 q) ]% v7 G- t
5. ndarray.flatten([order]) Return a copy of the array collapsed into one dimension. 示例代码如下: & ~2 t' W0 J; t0 b& i8 D! Q& D9 i# s* V
6. ndarray.T 数组的转置 将数组的行、列进行互换 示例代码如下: 2 @5 h C7 g& S { & y* w( }) [. T9 G$ Q7. ndarray.tostring([order])或者ndarray.tobytes([order]) Construct Python bytes containing the raw data bytes in the array. 转换成bytes, |& M# i& ^1 \' _9 j6 a
8 T9 }- `6 v/ h' B' c' d; B( A S# a
8. ndarray.copy([order]) Return a copy of the array. 当我们不想修改某个数据的时候,就可以去进行拷贝操作。在拷贝的数据上进行操作,示例代码如下: 1 T0 R' D' j* [- h* I9 E- W# m) ]3 p
0 r2 E9 h1 y$ T+ Q2 C
4. 数组运算4 W6 ~9 t- z5 i2 @+ _' i. z4 o: }% h% {
( a' V2 U$ H# q0 Y4.1 逻辑运算 * Y0 y4 O5 s8 c% a9 m4 U6 B & F' t4 S8 W2 g1 O3 w: g: a% n7 p0 ]) v" ^* Z! B
通用判断函数,np.all(),示例代码如下: / @" o# X9 I# @- |/ h + t/ K. ~! o0 m0 tnp.unique():返回新的数组的数值,不存在重复的值,示例代码如下: 3 D- r; N2 @- B6 J1 _ / z; @# q1 r/ b9 Enp.where (三元运算符):通过使用np.where能够进行更加复杂的运算,示例代码如下: ' i* T7 T c/ p O) P: G( S- M / T. K2 C1 a4 I% m8 w6 d! E; J+ U3 m. I7 o2 ?; f G1 L4 Z
4.2 统计运算0 H) V, A3 `% L6 i' M& A4 y
1 R4 |8 d0 P4 w7 M7 ^
在数据挖掘/机器学习领域,统计指标的值也是我们分析问题的一种方式。注意:进行统计的时候,axis轴 的取值并不一定, NumPy中不同的API轴的值都不一样,在这里,axis 0代表列, axis 1代表行 去进行统计。常用的指标如下: 7 h6 R* ~/ |: q* o& z4 K 2 e K! Z* P: p. d; smin(a[, axis, out, keepdims]) Return the minimum of an array or minimum along an axis. 示例代码如下: + p: q* x- q, C# Q/ ~ : h* a2 E3 A5 U( @9 ]max(a[, axis, out, keepdims]) Return the maximum of an array or maximum along an axis. 示例代码如下: 7 F; ~1 b9 \, u. i + N7 ?: U! ?$ ^! Q) x* imedian(a[, axis, out, overwrite_input, keepdims]) Compute the median along the specified axis. 示例代码如下: ' w0 q0 @$ a. `- u, o: ^) T- Z0 J
mean(a[, axis, dtype, out, keepdims]) Compute the arithmetic mean along the specified axis. 示例代码如下:! D; T) e4 P+ s: R _" C1 R# n% S( J% u
$ S4 l% M& `$ O7 b+ d Y, p( sstd(a[, axis, dtype, out, ddof, keepdims]) Compute the standard deviation along the specified axis. 示例代码如下: 1 i& A6 C% K+ P2 o0 p2 p2 a0 c! ?; [8 o0 I$ x
var(a[, axis, dtype, out, ddof, keepdims]) Compute the variance along the specified axis. 示例代码如下:3 b& Q1 `. c% W+ L7 [6 Z
; b9 p" J5 w3 f0 ?6 ?* I) |
np.argmax(temp, axis=) 示例代码如下:6 i$ M9 J( y( D& U. O/ W
6 R/ l6 ^. w( g
np.argmin(temp, axis=) 示例代码如下: # E8 l. L C: t; N: U3 A( w& @' N: r }; L8 |6 J
4.3 数组间运算 . ?- J8 ]1 P& w% x- a% V# _, @/ d
数组与数的运算,示例代码如下:3 z! h8 q+ C: S0 e( e3 {
& I5 h# M3 ~3 U% d( t矩阵运算,什么是矩阵?矩阵,英文matrix,和array的区别矩阵必须是2维的,但是array可以是多维的。示例代码如下: " g0 e y* b% @5 X! m6 H: x# Z8 g- u3 g Y0 L( V- w& T. R6 @
. G w' }# h. Z2 |
4.4 合并分割 1 f( }1 S% i/ C' U% O* K& |: [+ [& b2 c$ G# R" v+ R+ l) s* ]
numpy.concatenate((a1, a2, …), axis=0) 示例代码如下: & T, I1 p. d3 w% p8 n8 `! \& v% O+ k* k
numpy.hstack(tup) Stack arrays in sequence horizontally (column wise). 示例代码如下:0 E4 C3 ^/ s1 j# ^, X
' ]" F8 H' H: a6 \- C! s* z
numpy.vstack(tup) Stack arrays in sequence vertically (row wise). 示例代码如下: . u4 K* ~ ~$ |5 M2 ]5 @2 l & q# E" z6 X6 w+ w# g. bnumpy.split(ary, indices_or_sections, axis=0) Split an array into multiple sub-arrays. 示例代码如下:( |: d% m& n8 ]) J2 f5 \
; l4 K' T) r; M
————————————————8 l* W4 F- p3 y2 k. O( M
版权声明:本文为CSDN博主「Amo Xiang」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。 . V+ Z: E# j1 J$ z. H6 n! B原文链接:https://blog.csdn.net/xw1680/article/details/105931313 * l6 ~% t: ?- `& J 4 r& e; ~, l4 @0 a. {4 b& ]9 j# d1 ]