Python中True和False如何判断
这篇文章主要讲解了“Python中True和False如何判断”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python中True和False如何判断”吧!
1.True和False的逻辑取反
在对True和False进行逻辑取反时,不使用~,而要使用not。
因为在Python中,not才是逻辑取反,而~是按位取反。True和False对应的数值是1和0,~True就相当于对1按位取反,结果是-2,not True的结果才是False。
print(True)print(~True)print(not True)
结果是:
True
-2
False
类似的,~False的结果是1,not False 的结果才是True
print(False)print(~False)print(not False)
结果是:
False
-1
True
注:Python中 ~ 按位取反是按照数的补码取反,即:
1 => 补码00000001 => ~按位取反 => 补码11111110 => 2
双重否定的结果是这样的
print(not not True)print(~~True)print(not ~True)print(~(not True))
结果为:
True
1
False
-1
对False的双重否定
print(not not False)print(~~False)print(not ~False)print(~(not False))
结果为:
False
0
False
-2
2.if条件语句中的True和False
Python语言中,if后任何非0和非空(null)值为True,0或者null为False。这点和其他语言不相同,使用多种编程语言时很容易混淆。所以即使判断条件是一个负数,也是按照True处理,不会执行else分支。来看例子:
if (-2): print('a')else: print('b')
结果为:a
如果使用了~对True或False取反,则得不到想要的结果:
if (~True): # ~True == -2 print('a')else: print('b')
结果为:a
只有用not来取反,才能达到逻辑取反的效果:
if not True: print('a')else: print('b')
结果为:b
3.pandas.DataFrame.loc 中的否定
pandas.DataFrame.loc 官方文档中是这么说的
Access a group of rows and columns by label(s) or a boolean array.
可以使用布尔列表作为输入,包括使用一个条件式来返回一个布尔列表,例:
首先创建一个DataFrame
import pandas as pd df = pd.DataFrame([[1, 2], [4, 5], [7, 8]], index=['cobra', 'viper', 'sidewinder'], columns=['max_speed', 'shield']) df
使用条件式来筛选出shield大于6的数据
df.loc[df['shield'] > 6]
筛选出shield域小于等于6的数据,可以
df.loc[df['shield'] <= 6]
也可以用
~ df.loc[~(df['shield'] > 6)]
另一个例子,筛选出index中不包含er两个字母的数据
df.loc[~df.index.str.contains('er')]
需要注意的是,在这里使用df.index.str.contains('er')作为条件筛选时,返回的是pd.Series。
而在pd.Series中, ~操作符重载了,它对布尔类型数据和对数值类型数据的处理分别是逻辑取反和按位取反。
df.index.str.contains('er')
的结果是:
array([False, True, True])
对布尔类型的pd.Series使用~取反,是逻辑取反
~pd.Series([False, True, False])
结果为
True
False
True
dtype: bool
而如果对数值型的pd.Series使用~取反,则是按位取反
~pd.Series([1,2,3])
结果为
-2
-3
-4
dtype: int64
感谢各位的阅读,以上就是“Python中True和False如何判断”的内容了,经过本文的学习后,相信大家对Python中True和False如何判断这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341