赞
踩
在对numpy进行了几个小时的学习后,做出如下学习笔记
写完这边笔记后,过了几天补充一些理解:
- numpy处理的主要内容是数组,一维的,二维的,三维的,多维的。
- numpy的数组与python原生的数组在概念上基本类似,
- 但是在函数,方法上有很大区别。很多numpy数组的api,放到python原生数组上是不可用的。
import numpy库后,通过numpy参数操作示例
import numpy as np
# 创建ndarray,通过list创建
a = np.array([1, 2, 3])
print(a)
[1 2 3]
# 通过元组创建ndarray,并指定数据类型为float (此处是python的float类型,不是numpy的float类型)
b = np.array((2, 3, 4), dtype=float)
print("值", b, ", 类型", b.dtype)
值 [2. 3. 4.] , 类型 float64
# 创建复数类型
c = np.array([1+2j, 3+4j, 5+6j])
print("value:", c, ", type:", c.dtype)
value: [1.+2.j 3.+4.j 5.+6.j] , type: complex128
d = np.array(["你好", "hello", "world"])
print("value:", d, ", type:", d.dtype)
value: ['你好' 'hello' 'world'] , type: <U5
f = np.array([b"hello", b'world'])
print("value:", f, ", type:", f.dtype)
value: [b'hello' b'world'] , type: |S5
数据类型分为python的类型,与numpy的类型
比如:int_, intc, int8, int16, float16…等等。是numpy的数据类型,在使用是需要有numpy前缀
type01 = np.array([1, 2, 3], dtype = np.int8)
type01
array([1, 2, 3], dtype=int8)
小端与大端:存储时数据头尾与内存前后的关系相反
dt = np.dtype('<u4') # uint32位,小端存储
g = np.array([1, 2, 3], dtype = dt)
print(g, g.dtype)
[1 2 3] uint32
通过astype()可以转换array元素的数据类型,如果转换类型不兼容会报错
h = np.array(["1", "2.3", "4.5"])
ht = h.astype("f4") # f4: float32
ht
array([1. , 2.3, 4.5], dtype=float32)
arange函数创建数值范围并返回数组对象,与python中range函数类似。语法格式如下:
numpy.arange([start,] stop, [step,] dtype=None)
a = np.arange(10)
a
array([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])
a = np.arange(1, 10, 2)
a
array([1, 3, 5, 7, 9])
a = np.arange(1, -10, -3, dtype=np.float32)
a
array([ 1., -2., -5., -8.], dtype=float32)
linsapce函数创建等差数列,语法格式如下:
numpy.linspace(start, stop, num=50, endpoint=True, retstep=False, dtype=None)
a = np.linspace(0, 10, 10)
a
array([ 0. , 1.11111111, 2.22222222, 3.33333333, 4.44444444,
5.55555556, 6.66666667, 7.77777778, 8.88888889, 10. ])
a = np.linspace(0, 10, 10, retstep=True)
a
(array([ 0. , 1.11111111, 2.22222222, 3.33333333, 4.44444444,
5.55555556, 6.66666667, 7.77777778, 8.88888889, 10. ]),
1.1111111111111112)
当retstep=True时,函数返回内容为二元数组,第一个元素是等差数列,第二个元素是步长
a[1]
1.1111111111111112
numpy.logspace(start, stop, num=50, endpoint=True, base=10.0, dtype=None)
a = np.logspace(0, 9, 10)
a
array([1.e+00, 1.e+01, 1.e+02, 1.e+03, 1.e+04, 1.e+05, 1.e+06, 1.e+07,
1.e+08, 1.e+09])
1e+1:1乘以10的1次方
ne+x: n乘以10的x次方
a = np.logspace(0, 9, 10, base=2)
a
array([ 1., 2., 4., 8., 16., 32., 64., 128., 256., 512.])
import numpy as np
arr = np.array([1, 2, 3, 4, 5])
arr2 = arr[arr % 2 == 1]
arr2
array([1, 3, 5])
arr = np.linspace(2.5, 6.5, num=30, endpoint=True, retstep=True)
arr
(array([2.5 , 2.63793103, 2.77586207, 2.9137931 , 3.05172414,
3.18965517, 3.32758621, 3.46551724, 3.60344828, 3.74137931,
3.87931034, 4.01724138, 4.15517241, 4.29310345, 4.43103448,
4.56896552, 4.70689655, 4.84482759, 4.98275862, 5.12068966,
5.25862069, 5.39655172, 5.53448276, 5.67241379, 5.81034483,
5.94827586, 6.0862069 , 6.22413793, 6.36206897, 6.5 ]),
0.13793103448275862)
a = np.array([[1, 2, 3], [4, 5, 6], [7, 8, 9]])
a
array([[1, 2, 3],
[4, 5, 6],
[7, 8, 9]])
shape属性可以返回数组的形状,简单理解为:几乘几
a.shape
(3, 3)
数组对象的reshape方法可以修改数组形状
a = np.arange(0, 10)
print("a:", a)
# 将一维数组设置成2行5列的二维数组
a = a.reshape(2, 5)
print("a reshape:", a)
b = np.arange(0, 27)
print("b:", b)
# 将一维数组b reshape成3*3*3的三维数组
b = b.reshape(3, 3, 3)
print("b reshape:", b)
a: [0 1 2 3 4 5 6 7 8 9] a reshape: [[0 1 2 3 4] [5 6 7 8 9]] b: [ 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] b reshape: [[[ 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]]]
numpy.ones(shape, dtype=None)
dtype不指定时,float
a = np.ones((2, 3))
a
array([[1., 1., 1.],
[1., 1., 1.]])
a = np.ones((2, 3), dtype=np.int32)
a
array([[1, 1, 1],
[1, 1, 1]])
未初始化:内存里保存的是原始值,可能是空,也可能是上一次操作后保留在内存里的值
e = np.empty((2, 3))
e
array([[0., 0., 0.],
[0., 0., 0.]])
e = np.empty((3, 7))
e
array([[6.23042070e-307, 4.67296746e-307, 1.69121096e-306,
1.29061414e-306, 8.34441742e-308, 8.90104239e-307,
1.33511290e-306],
[1.42417221e-306, 1.60220393e-306, 1.02359848e-306,
3.11525958e-307, 1.69118108e-306, 8.06632139e-308,
1.20160711e-306],
[1.69119330e-306, 1.29062229e-306, 6.89804133e-307,
1.11261162e-306, 8.34443015e-308, 1.42404727e-306,
3.39986383e-317]])
上面e = np.empty((3, 7))执行后,e的内容不是0,而是上次内存操作后留下的值
full函数根据指定的形状和数据类型生成数组,并用指定的数据填充,语法格式如下:
numpy.full(shape, fill_value, dtype=None)
# 创建2行4列,元素value都是10的二维数组
a = np.full((2, 4), 10)
a
array([[10, 10, 10, 10],
[10, 10, 10, 10]])
# 创建5个元素的一维数组,每个元素value都是3
a = np.full(5, 3, dtype=np.float32)
a
array([3., 3., 3., 3., 3.], dtype=float32)
numpy.identity(n, dtype=None)
numpy.eye(N, M=None, k=0, dtype=float)
i = np.identity(3)
i
array([[1., 0., 0.],
[0., 1., 0.],
[0., 0., 1.]])
e = np.eye(3, 4, 0, dtype=np.int32)
e
array([[1, 0, 0, 0],
[0, 1, 0, 0],
[0, 0, 1, 0]])
简单来说,二维数组的行:0轴,二维数组的列:1轴
x = np.array([['a', 'b', 'c', 'd', 'e'], ['h', 'i', 'j', 'k', 'l'], ['o', 'p', 'q', 'r', 's']])
x
array([['a', 'b', 'c', 'd', 'e'],
['h', 'i', 'j', 'k', 'l'],
['o', 'p', 'q', 'r', 's']], dtype='<U1')
# 通过轴获取二维数组中对应的元素:
x[2, 3]
# 其实就是几行几列
'r'
数组的T属性可以转置数组,将数组轴的索引倒置。说人话就是行专列,列转行
t1 = np.array([[1, 2, 3], [4, 5, 6]])
t1
array([[1, 2, 3],
[4, 5, 6]])
# 使用T属性转置多维数组
t1.T
array([[1, 4],
[2, 5],
[3, 6]])
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。