numpy的基本操作

1.常用方法创建array

print(np.array([1, 2, 3], dtype="f4"))# 32位浮点型

print(np.array([1.5, 2.2, 3]))# 默认浮点型

print(np.array([1, 2, 3, 4, 5], ndmin=3))# 3维数组

print(np.array([range(i, i + 5) for i in [1, 2, 3]]))#

print(np.zeros(shape=[5, 5], dtype="i4"))# 5x5的0数组

print(np.ones(shape=[5, 5], dtype="i4"))# 5x5的1数组

print(np.array(["1.1", "2.2", "3.3"], dtype="S").astype("f4"))# 字符串数组转为浮点型数组

# 所有非零元素的索引
a=np.nonzero(np.array([1, 0, 2, 3, 0, 4]))#
print(a)#(array([0, 2, 3, 5], dtype=int64),)
print(a[0])# [0 2 3 5]

print(np.full(shape=[5, 5], fill_value=1.5, dtype=np.float_))# 5x5的1.5数组


print(np.eye(10))# 10x10的单位阵


# 数组元素为随机值,因为它们未初始化


print(np.empty(shape=(5, 5)))# 5x5的未初始化数组


print(np.linspace(1, 10, 5))# 返回num个等间距的样本

 

 


 

print(np.random.random((5, 5)))# 随机生成5行5列

# 生成[0, 10) 且 3行3列的随机数
# 生成的数据包括起始值和结束值,但不包括结束值本身。
print(np.random.randint(0, 10, (3, 3)))# 3x3的随机整数数组, 值在[0, 10)

print(np.random.normal(0, 1, (3, 3)))# 3x3的正态分布随机数, 均值为0, 方差为1

print(np.array([1, 2, 3]).itemsize)# 元素字节大小, 32位=4字节

2. Numpy 索引和切片 

在Python中,切片(slice)是对序列型对象(如list, string, tuple)的一种高级索引方法。
普通索引只取出序列中一个下标对应的元素,而切片取出序列中一个范围对应的元素

2.1普通索引

一维的索引
a1 = np.array([1, 2, 3, 4])
print(a1)
print(a1[0])
print(a1[2])

二维的索引
a2 = np.array([
[1, 2, 3],
[4, 5, 6],
[7, 8, 9]
])
print(a2[2])
print(a2[2, 1])
print(a2[:, 2])# 第2列元素,行索引省略表示所有行


a3 = np.array([
    [[10, 11, 12], [13, 14, 15], [16, 17, 18]],
    [[20, 21, 22], [23, 24, 25], [26, 27, 28]],
    [[30, 31, 32], [33, 34, 35], [36, 37, 38]]
])

# 打印数组 a3 的形状
print(a3.shape)  

# 打印 a3 的第三层(索引为 2)
print(a3[2])  

# 打印 a3 第三层的第一层(索引为 2,0)
print(a3[2, 0])  

# 打印 a3 第三层第一层的第二个元素(索引为 2,0,1)
print(a3[2, 0, 1])  

# 打印 a3 所有层的第二层的第三个元素(索引为 :,1,2)
print(a3[:, 1, 2])  

# 打印 a3 第二层的第三层(索引为 1,2)
print(a3[1, 2])  

# 打印 a3 第一层的所有元素(索引为 0,:)
print(a3[0, :])  

# 打印 a3 第一层的所有第二层元素(索引为 0,:,1)
print(a3[0, :, 1])  

# 打印 a3 所有层的第二层(索引为 :,1)
print(a3[:, 1])  

# 打印 a3 所有层的第二层的第一个元素(索引为 :,1,0)
print(a3[:, 1, 0])  

# 打印 a3 所有层的第二层和第三层的第一个元素(索引为 :,1:3,0)
print(a3[:, 1:3, 0])  

# 打印 a3 所有层的前两层的前两层(索引为 :,:2,:2)
print(a3[:, :2, :2])  

# 打印 a3 第二层的第二层和第三层的第二个元素(索引为 1:2,1:3,1)
print(a3[1:2, 1:3, 1])  

print(a3[:, 0, 1])  # 打印所有层的第一层的第二个元素

print(a3[:, ::2, 1])  # 打印所有层的隔一个元素的层的第二层元素

print(a3[:, [0, 2], [0, 1]])  # 以特定索引组合打印元素

2.2索引可以是array数组

data = np.array([1, 2, 3, 4, 5, 6, 7, 8, 9])
mask1 = np.array([True, False, True, False, True, False, True, False, True],dtype=np.bool_)
index = np.array([1, 0, 1, 0, 1, 0, 1, 0, 1], dtype="i1")
print(data[mask1])# 索引为True的元素

# index表示索引 将data对应的索引选择出来
print(data[index])# 索引为1,0,1,0的元素

data = np.array([1, 2, 3, 4, 5, 6, 7, 8, 9])
index = np.array([2, 4, 1, 0], dtype="i1")
print(data[index])# 索引为2,4,1,0的元素

2.3高级索引
 

arr = np.array([
    [1, 2, 3],
    [4, 5, 6],
    [7, 8, 9]])
# 使用整数数组索引选择元素
indices = np.array([0, 2])
result = arr[:, indices]# 选择第0列和第2列,即第0行和第2行
#result = arr[:, [0, 2]]#与上一行等价
print(result)

  • 14
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

西柚与蓝莓

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值