Python扩展库numpy中的布尔运算

首先解答上一篇文章Win10系统配置Python3.6+OpenGL环境详细步骤中的问题。该问题的答案为[2, 2],要点在于列表对象的方法index()默认是返回指定元素在列表中首次出现的下标,元组和字符串的index()方法也具有相同的用法。

在该文问题中,如果想要获取列表中3的所有位置,列表推导式应写为[i for i,v in enumerate(x) if v==3]。

----------分割线---------

numpy支持一个数组与一个标量之间(或两个等长数组)之间的关系运算,得到一个新数组,新数组中每个元素为True或False,表示原数组中所有元素与该标量(或原来两个数组中对应元素)进行关系运算的结果。当使用仅含有True或False的numpy数组作为下标访问数组元素时,可以将False对应的元素过滤掉,只保留True对应的。

# 包含10个随机数的数组

>>> import numpy as np

>>> x = np.random.rand(10) 

>>> x

array([ 0.56707504,  0.07527513,  0.0149213 ,  0.49157657,  0.75404095,

      0.40330683,  0.90158037,  0.36465894,  0.37620859,  0.62250594])

# 比较数组中每个元素值是否大于0.5

>>> x > 0.5

array([ True, False, False, False,  True, False,  True, False, False,  True], dtype=bool)

# 获取数组中大于0.5的元素,可用于检测和过滤异常值

>>> x[x>0.5]

array([ 0.56707504,  0.75404095,  0.90158037,  0.62250594])

>>> x < 0.5

array([False,  True,  True,  True, False,  True, False,  True,  True, False], dtype=bool)

# 测试是否全部元素都小于1

>>> np.all(x<1)

True

# 是否存在等价于True的元素

>>> np.any([1,2,3,4])

True

>>> np.any([0])

False

>>> a = np.array([1, 2, 3])

>>> b = np.array([3, 2, 1])

# 两个数组中对应位置上的元素比较

>>> a > b

array([False, False,  True], dtype=bool)

>>> a[a>b]

array([3])

>>> a == b

array([False,  True, False], dtype=bool)

>>> a[a==b]

array([2])

-----------分割线------------

今日习题:表达式sorted([111, 2, 33], key=lambda x: -len(str(x)))的值是什么?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

dongfuguo

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

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

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

打赏作者

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

抵扣说明:

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

余额充值