检查Python中的枚举中是否存在值
要检查 Python 中的枚举中是否存在值:
- 使用列表推导获取所有枚举值的列表。
-
使用
in
运算符检查值是否存在于列表中。 -
如果值在列表中,
in
运算符将返回 True。
from enum import Enum
class Sizes(Enum):
SMALL = 1
MEDIUM = 2
LARGE = 3
values = [member.value for member in Sizes]
print(values) # 👉️ [1, 2, 3]
if 2 in values:
# 👇️ this runs
print('2 is in enum values')
else:
print('2 is NOT in enum values')
print(100 in values) # 👉️ False
我们使用列表推导来获取枚举值的列表。
列表推导
用于对每个元素执行一些操作,或者选择满足条件的元素子集。
最后一步是使用 in
运算符检查特定值是否在列表中。
in
运算符测试成员资格。 例如,如果 x 是 l 的成员,则 x in l 计算结果为 True,否则计算结果为 False。
如果我们需要检查一个值是否不在枚举中,请用 not
否定条件。
from enum import Enum
class Sizes(Enum):
SMALL = 1
MEDIUM = 2
LARGE = 3
values = [member.value for member in Sizes]
print(values) # 👉️ [1, 2, 3]
if 100 not in values:
# 👇️ this runs
print('100 is NOT in enum values')
如果我们需要检查枚举中是否存在特定名称,则可以使用相同的方法。
from enum import Enum
class Sizes(Enum):
SMALL = 1
MEDIUM = 2
LARGE = 3
names = [member.name for member in Sizes]
print(names) # 👉️ ['SMALL', 'MEDIUM', 'LARGE']
if 'SMALL' in names:
# 👇️ this runs
print('SMALL is in enum names')
我们没有访问 value
属性,而是使用 name
属性来获取枚举名称的列表。
相关文章
Python pandas.pivot_table() 函数
发布时间:2024/04/24 浏览次数:82 分类:Python
-
Python Pandas pivot_table()函数通过对数据进行汇总,避免了数据的重复。
在 Python 中将 Pandas 系列的日期时间转换为字符串
发布时间:2024/04/24 浏览次数:894 分类:Python
-
了解如何在 Python 中将 Pandas 系列日期时间转换为字符串
在 Python Pandas 中使用 str.split 将字符串拆分为两个列表列
发布时间:2024/04/24 浏览次数:1124 分类:Python
-
本教程介绍如何使用 pandas str.split() 函数将字符串拆分为两个列表列。
在 Pandas 中将 Timedelta 转换为 Int
发布时间:2024/04/23 浏览次数:231 分类:Python
-
可以使用 Pandas 中的 dt 属性将 timedelta 转换为整数。
Python 中的 Pandas 插入方法
发布时间:2024/04/23 浏览次数:112 分类:Python
-
本教程介绍了如何在 Pandas DataFrame 中使用 insert 方法在 DataFrame 中插入一列。
使用 Python 将 Pandas DataFrame 保存为 HTML
发布时间:2024/04/21 浏览次数:106 分类:Python
-
本教程演示如何将 Pandas DataFrame 转换为 Python 中的 HTML 表格。
如何将 Python 字典转换为 Pandas DataFrame
发布时间:2024/04/20 浏览次数:73 分类:Python
-
本教程演示如何将 python 字典转换为 Pandas DataFrame,例如使用 Pandas DataFrame 构造函数或 from_dict 方法。
如何在 Pandas 中将 DataFrame 列转换为日期时间
发布时间:2024/04/20 浏览次数:101 分类:Python
-
本文介绍如何将 Pandas DataFrame 列转换为 Python 日期时间。