0%

一文学懂NumPy基础知识1

NumPy可以用来干什么?

在python里面已经有了列表list,为什么还要使用NumPy?

这和list与NumPy在数据储存和运算速度有关。提升内存和计算资源的利用效率。

NumPy最重要的知识包括:

  • ndarray(N-dimensional array object),解决多维数组问题,
  • ufunc(universal function object),解决对数组进行处理的函数。

ndarray

array表示数据,ndarray代表多维数组。

创建数组

1
2
3
4
5
6
7
8
import numpy as np
a = np.array([1, 2, 3])
b = np.array([[1, 1, 2], [2, 3, 5], [3, 4, 5]])
b[1, 1]=10
print(a.shape)
print(b.shape)
print(a.dtype)
print(b)

输出结果为

1
2
3
4
5
6
(3,)
(3, 3)
int64
[[ 1 1 2]
[ 2 10 5]
[ 3 4 5]]

总结:

  • shape用于获取数组的大小;
  • dtype用于获取数组的属性;
  • b[1, 1]表示对数组进行修改,从零开始计数,上面代码把b中的每个数组看成一个整体,当成一个数。

结构数组

创建储存每个数字单元的表格。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
import numpy as np
# 定义数组结构
persontype = np.dtype({
'names':['name', 'age', 'chinese', 'math', 'English'],
'formats':['S32', 'i', 'i', 'i', 'f']})

peoples = np.array([('A', 1, 2, 3, 4),
('B', 4, 6, 7, 8),
('C', 0, 8, 8, 5),
('D', 3, 7, 8, 1)],
dtype = persontype)

ages = peoples[:]['age']
chineses = peoples[:]['chinese']
maths = peoples[:]['math']
Englishs = peoples[:]['English']

# 计算平均值
print(np.mean(ages))
print(np.mean(chineses))
print(np.mean(maths))
print(np.mean(Englishs))

输出结果为:

1
2
3
4
2.0
5.75
6.5
4.5

ufunc

universal function的缩写。

创建连续数组

1
2
3
4
5
6
import numpy as np
x1 = np.arange(1, 11, 2)
x2 = np.linspace(1, 9 ,5)

print(x1)
print(x2)

输出结果为:

1
2
[1 3 5 7 9]
[1. 3. 5. 7. 9.]

arange是range的内置函数,arange(1, 11, 2)分别代表初始值、终值、步长

linspaces是linear space的缩写,代表线性等分向量。linespace(1, 9,5)分别代表初始值,重值(含),元素个数。

运算

基本运算

可以进行加、剪、乘、除、n次方,取余数等运算

1
2
3
4
5
6
7
8
9
10
import numpy as np
x1 = np.arange(1, 11, 2)
x2 = np.linspace(1, 9 ,5)

print(np.add(x1, x2))
print(np.subtract(x1, x2))
print(np.multiply(x1, x2))
print(np.divide(x1, x2))
print(np.power(x1, x2))
print(np.remainder(x1, x2))

输出结果为:

1
2
3
4
5
6
7
[ 2.  6. 10. 14. 18.]
[0. 0. 0. 0. 0.]
[ 1. 9. 25. 49. 81.]
[1. 1. 1. 1. 1.]
[1.00000000e+00 2.70000000e+01 3.12500000e+03 8.23543000e+05
3.87420489e+08]
[0. 0. 0. 0. 0.]

在进行计算时,需要保证数组的秩相同,即每个列表的元素个数相同,方可进行运算。

统计学相关的运算

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
# -*- coding:utf-8 -*-

import numpy as np

a = np.array([[1, 2, 3],[4, 5, 6],[7, 8, 9]])

print(np.amin(a)) # 最小值
print(np.amin(a, 0)) # 每一列中的的最小值
print(np.amin(a, 1)) # 每一行中的最小值
print(np.amax(a)) # 最大值
print(np.amax(a, 0)) # 每一列中的最大值
print(np.amax(a, 1)) # 每一行的最小值

# 统计最大值与最小值之差
print(np.ptp(a))
print(np.ptp(a, 0))
print(np.ptp(a, 1))

# 求中位数与平均数
print(np.median(a)) # 整体列表中位数
print(np.median(a, axis=0)) # 求每一列的中位数
print(np.median(a, axis=1)) # 求每一行的中位数
print(np.mean(a)) # 求整体列表的平均数
print(np.mean(a, axis=0)) # 求每一列的平均数
print(np.mean(a, axis=1)) # 求每一行的平均数

# 求加权平均数
a = np.array([1, 2, 3, 4])
wts = np.array([1, 2, 3, 4])
print(np.average(a)) # 默认权重相同
print(np.average(a, weights=wgt)) # 赋予不同权重 (1*1=2*2+3*3+4*4)/(1+2+3+4)

# 求标准差方差
print(np.std(a)) # 标注差
print(np.var(a)) # 方差

输出结果为:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
1
[1 2 3]
[1 4 7]
9
[7 8 9]
[3 6 9]

8
[6 6 6]
[2 2 2]

5.0
[4. 5. 6.]
[2. 5. 8.]
5.0
[4. 5. 6.]
[2. 5. 8.]

2.5
3.0

1.118033988749895
1.25

从行列式角度理解,axis=0表示列,axis=1表示行。

NumPy进行排序

排序在数据分析中使用频率很高,一般排序语句结构为:

1
sort(a, axis=-1, kind=‘quicksort’, order=None)

默认情况下axis=-1,表示对内部列表分别排序。当axis=None时,表示把所有数字按照一个列表排序。

Kind包含三种结构:quicksort、mergesort、heapsort ,分别代表快速排序、合并排序、堆排序。默认情况下,使用的是quicksort排序。

1
2
3
4
5
6
7
8
import numpy as np

a = np.array([[14, 55, 9], [45, 56, 87], [90, 3, 45]])

print(np.sort(a))
print(np.sort(a, axis=None))
print(np.sort(a, axis=0))
print(np.sort(a, axis=1))

输出结果为:

1
2
3
4
5
6
7
8
9
10
[[ 9 14 55]
[45 56 87]
[ 3 45 90]]
[ 3 9 14 45 45 55 56 87 90]
[[14 3 9]
[45 55 45]
[90 56 87]]
[[ 9 14 55]
[45 56 87]
[ 3 45 90]]

参考资料

《数据分析实战45讲》-极课时间 陈旸

ChangeLog

20201025 完成基本内容