百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

python 系列(枚举类型)(python枚举类型enum用法)

off999 2024-09-18 22:40 51 浏览 0 评论

枚举 - 枚举类型

该enum模块定义了具有迭代和比较功能的枚举类型。它可用于为值创建定义明确的符号,而不是使用文字整数或字符串。

创建枚举

class通过子类化Enum和添加描述值的类属性,使用语法 定义新的枚举。

enum_create.py

import enum
class BugStatus(enum.Enum):
 new = 7
 incomplete = 6
 invalid = 5
 wont_fix = 4
 in_progress = 3
 fix_committed = 2
 fix_released = 1
print('\nMember name: {}'.format(BugStatus.wont_fix.name))
print('Member value: {}'.format(BugStatus.wont_fix.value))

在Enum解析类时,将成员转换为实例。每个实例都具有name与成员名称value对应的属性以及与在类定义中分配给名称的值对应的属性。

$ python3 enum_create.py
Member name: wont_fix
Member value: 4

迭代

迭代枚举会产生枚举的各个成员。

enum_iterate.py

import enum
class BugStatus(enum.Enum):
 new = 7
 incomplete = 6
 invalid = 5
 wont_fix = 4
 in_progress = 3
 fix_committed = 2
 fix_released = 1
for status in BugStatus:
 print('{:15} = {}'.format(status.name, status.value))

成员按照在类定义中声明的顺序生成。名称和值不用于以任何方式对它们进行排序。

$ python3 enum_iterate.py
new = 7
incomplete = 6
invalid = 5
wont_fix = 4
in_progress = 3
fix_committed = 2
fix_released = 1

比较枚举

由于枚举成员未被排序,因此它们仅支持通过标识和相等性进行比较。

enum_comparison.py

import enum
class BugStatus(enum.Enum):
 new = 7
 incomplete = 6
 invalid = 5
 wont_fix = 4
 in_progress = 3
 fix_committed = 2
 fix_released = 1
actual_state = BugStatus.wont_fix
desired_state = BugStatus.fix_released
print('Equality:',
 actual_state == desired_state,
 actual_state == BugStatus.wont_fix)
print('Identity:',
 actual_state is desired_state,
 actual_state is BugStatus.wont_fix)
print('Ordered by value:')
try:
 print('\n'.join(' ' + s.name for s in sorted(BugStatus)))
except TypeError as err:
 print(' Cannot sort: {}'.format(err))

大于和小于比较运算符引发 TypeError异常。

$ python3 enum_comparison.py
Equality: False True
Identity: False True
Ordered by value:
 Cannot sort: '<' not supported between instances of 'BugStatus
' and 'BugStatus'

将IntEnum类用于枚举,其中成员需要表现得更像数字 - 例如,以支持比较。

enum_intenum.py

import enum
class BugStatus(enum.IntEnum):
 new = 7
 incomplete = 6
 invalid = 5
 wont_fix = 4
 in_progress = 3
 fix_committed = 2
 fix_released = 1
print('Ordered by value:')
print('\n'.join(' ' + s.name for s in sorted(BugStatus)))
$ python3 enum_intenum.py
Ordered by value:
 fix_released
 fix_committed
 in_progress
 wont_fix
 invalid
 incomplete
 new

唯一枚举值

具有相同值的枚举成员将作为对同一成员对象的别名引用进行跟踪。别名不会导致重复值存在于迭代器中Enum。

enum_aliases.py

import enum
class BugStatus(enum.Enum):
 new = 7
 incomplete = 6
 invalid = 5
 wont_fix = 4
 in_progress = 3
 fix_committed = 2
 fix_released = 1
 by_design = 4
 closed = 1
for status in BugStatus:
 print('{:15} = {}'.format(status.name, status.value))
print('\nSame: by_design is wont_fix: ',
 BugStatus.by_design is BugStatus.wont_fix)
print('Same: closed is fix_released: ',
 BugStatus.closed is BugStatus.fix_released)

因为by_design并且closed是其他成员的别名,所以当迭代时,它们不会在输出中单独出现 Enum。成员的规范名称是附加到值的第一个名称。

$ python3 enum_aliases.py
new = 7
incomplete = 6
invalid = 5
wont_fix = 4
in_progress = 3
fix_committed = 2
fix_released = 1
Same: by_design is wont_fix: True
Same: closed is fix_released: True

要要求所有成员都具有唯一值,请将@unique 装饰器添加到Enum。

enum_unique_enforce.py

import enum
@enum.unique
class BugStatus(enum.Enum):
 new = 7
 incomplete = 6
 invalid = 5
 wont_fix = 4
 in_progress = 3
 fix_committed = 2
 fix_released = 1
 # This will trigger an error with unique applied.
 by_design = 4
 closed = 1

具有重复值的成员在解释类ValueError时会触发异常Enum。

$ python3 enum_unique_enforce.py
Traceback (most recent call last):
 File "enum_unique_enforce.py", line 11, in <module>
 class BugStatus(enum.Enum):
 File ".../lib/python3.6/enum.py", line 834, in unique
 (enumeration, alias_details))
ValueError: duplicate values found in <enum 'BugStatus'>:
by_design -> wont_fix, closed -> fix_released

以编程方式创建枚举

在某些情况下,以编程方式创建枚举更方便,而不是在类定义中对它们进行硬编码。对于这些情况,Enum还支持将成员名称和值传递给类构造函数。

enum_programmatic_create.py

import enum
BugStatus = enum.Enum(
 value='BugStatus',
 names=('fix_released fix_committed in_progress '
 'wont_fix invalid incomplete new'),
)
print('Member: {}'.format(BugStatus.new))
print('\nAll members:')
for status in BugStatus:
 print('{:15} = {}'.format(status.name, status.value))

该value参数是枚举,其被用于建立成员的表示的名称。该names参数列表枚举的成员。当传递单个字符串时,它将在空格和逗号上拆分,并且生成的标记将用作成员的名称,这些成员将自动分配以值开头的值1。

$ python3 enum_programmatic_create.py
Member: BugStatus.new
All members:
fix_released = 1
fix_committed = 2
in_progress = 3
wont_fix = 4
invalid = 5
incomplete = 6
new = 7

为了更好地控制与成员关联的值, names可以使用两部分元组序列或将名称映射到值的字典替换字符串。

enum_programmatic_mapping.py

import enum
BugStatus = enum.Enum(
 value='BugStatus',
 names=[
 ('new', 7),
 ('incomplete', 6),
 ('invalid', 5),
 ('wont_fix', 4),
 ('in_progress', 3),
 ('fix_committed', 2),
 ('fix_released', 1),
 ],
)
print('All members:')
for status in BugStatus:
 print('{:15} = {}'.format(status.name, status.value))

在此示例中,给出了由两部分组成的元组的列表,而不是仅包含成员名称的单个字符串。这使得可以BugStatus使用与定义的版本相同的顺序重建枚举的枚举enum_create.py。

$ python3 enum_programmatic_mapping.py
All members:
new = 7
incomplete = 6
invalid = 5
wont_fix = 4
in_progress = 3
fix_committed = 2
fix_released = 1

非整数成员值

枚举成员值不限于整数。实际上,任何类型的对象都可以与成员相关联。如果值是元组,则成员将作为单独的参数传递给__init__()。

enum_tuple_values.py

import enum
class BugStatus(enum.Enum):
 new = (7, ['incomplete',
 'invalid',
 'wont_fix',
 'in_progress'])
 incomplete = (6, ['new', 'wont_fix'])
 invalid = (5, ['new'])
 wont_fix = (4, ['new'])
 in_progress = (3, ['new', 'fix_committed'])
 fix_committed = (2, ['in_progress', 'fix_released'])
 fix_released = (1, ['new'])
 def __init__(self, num, transitions):
 self.num = num
 self.transitions = transitions
 def can_transition(self, new_state):
 return new_state.name in self.transitions
print('Name:', BugStatus.in_progress)
print('Value:', BugStatus.in_progress.value)
print('Custom attribute:', BugStatus.in_progress.transitions)
print('Using attribute:',
 BugStatus.in_progress.can_transition(BugStatus.new))

在此示例中,每个成员值是一个元组,其中包含数字ID(例如可能存储在数据库中)和远离当前状态的有效转换列表。

$ python3 enum_tuple_values.py
Name: BugStatus.in_progress
Value: (3, ['new', 'fix_committed'])
Custom attribute: ['new', 'fix_committed']
Using attribute: True

对于更复杂的情况,元组可能变得笨拙。由于成员值可以是任何类型的对象,因此字典可用于存在大量单独属性以跟踪每个枚举值的情况。复数值直接传递给 __init__()除了以外的唯一参数self。

enum_complex_values.py

import enum
class BugStatus(enum.Enum):
 new = {
 'num': 7,
 'transitions': [
 'incomplete',
 'invalid',
 'wont_fix',
 'in_progress',
 ],
 }
 incomplete = {
 'num': 6,
 'transitions': ['new', 'wont_fix'],
 }
 invalid = {
 'num': 5,
 'transitions': ['new'],
 }
 wont_fix = {
 'num': 4,
 'transitions': ['new'],
 }
 in_progress = {
 'num': 3,
 'transitions': ['new', 'fix_committed'],
 }
 fix_committed = {
 'num': 2,
 'transitions': ['in_progress', 'fix_released'],
 }
 fix_released = {
 'num': 1,
 'transitions': ['new'],
 }
 def __init__(self, vals):
 self.num = vals['num']
 self.transitions = vals['transitions']
 def can_transition(self, new_state):
 return new_state.name in self.transitions
print('Name:', BugStatus.in_progress)
print('Value:', BugStatus.in_progress.value)
print('Custom attribute:', BugStatus.in_progress.transitions)
print('Using attribute:',
 BugStatus.in_progress.can_transition(BugStatus.new))

此示例使用字典而不是元组表示与上一示例相同的数据。

$ python3 enum_complex_values.py
Name: BugStatus.in_progress
Value: {'num': 3, 'transitions': ['new', 'fix_committed']}
Custom attribute: ['new', 'fix_committed']
Using attribute: True

相关推荐

安全教育登录入口平台(安全教育登录入口平台官网)

122交通安全教育怎么登录:122交通网的注册方法是首先登录网址http://www.122.cn/,接着打开网页后,点击右上角的“个人登录”;其次进入邮箱注册,然后进入到注册页面,输入相关信息即可完...

大鱼吃小鱼经典版(大鱼吃小鱼经典版(经典版)官方版)

大鱼吃小鱼小鱼吃虾是于谦跟郭麒麟的《我的棒儿呢?》郭德纲说于思洋郭麒麟作诗的相声,最后郭麒麟做了一首,师傅躺在师母身上大鱼吃小鱼小鱼吃虾虾吃水水落石出师傅压师娘师娘压床床压地地动山摇。...

谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
  • 谷歌地球下载高清卫星地图(谷歌地球地图下载器)
哪个软件可以免费pdf转ppt(免费的pdf转ppt软件哪个好)
哪个软件可以免费pdf转ppt(免费的pdf转ppt软件哪个好)

要想将ppt免费转换为pdf的话,我们建议大家可以下一个那个wps,如果你是会员的话,可以注册为会员,这样的话,在wps里面的话,就可以免费将ppt呢转换为pdfpdf之后呢,我们就可以直接使用,不需要去直接不需要去另外保存,为什么格式转...

2026-02-04 09:03 off999

电信宽带测速官网入口(电信宽带测速官网入口app)

这个网站看看http://www.swok.cn/pcindex.jsp1.登录中国电信网上营业厅,宽带光纤,贴心服务,宽带测速2.下载第三方软件,如360等。进行在线测速进行宽带测速时,尽...

植物大战僵尸95版手机下载(植物大战僵尸95 版下载)

1可以在应用商店或者游戏平台上下载植物大战僵尸95版手机游戏。2下载教程:打开应用商店或者游戏平台,搜索“植物大战僵尸95版”,找到游戏后点击下载按钮,等待下载完成即可安装并开始游戏。3注意:确...

免费下载ppt成品的网站(ppt成品免费下载的网站有哪些)

1、Chuangkit(chuangkit.com)直达地址:chuangkit.com2、Woodo幻灯片(woodo.cn)直达链接:woodo.cn3、OfficePlus(officeplu...

2025世界杯赛程表(2025世界杯在哪个国家)

2022年卡塔尔世界杯赛程公布,全部比赛在卡塔尔境内8座球场举行,2022年,决赛阶段球队全部确定。揭幕战于当地时间11月20日19时进行,由东道主卡塔尔对阵厄瓜多尔,决赛于当地时间12月18日...

下载搜狐视频电视剧(搜狐电视剧下载安装)

搜狐视频APP下载好的视频想要导出到手机相册里方法如下1、打开手机搜狐视频软件,进入搜狐视频后我们点击右上角的“查找”,找到自已喜欢的视频。2、在“浏览器页面搜索”窗口中,输入要下载的视频的名称,然后...

pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
  • pubg免费下载入口(pubg下载入口官方正版)
永久免费听歌网站(丫丫音乐网)

可以到《我爱音乐网》《好听音乐网》《一听音乐网》《YYMP3音乐网》还可以到《九天音乐网》永久免费听歌软件有酷狗音乐和天猫精灵,以前要跳舞经常要下载舞曲,我从QQ上找不到舞曲下载就从酷狗音乐上找,大多...

音乐格式转换mp3软件(音乐格式转换器免费版)

有两种方法:方法一在手机上操作:1、进入手机中的文件管理。2、在其中选择“音乐”,将显示出手机中的全部音乐。3、点击“全选”,选中所有音乐文件。4、点击屏幕右下方的省略号图标,在弹出菜单中选择“...

电子书txt下载(免费的最全的小说阅读器)

1.Z-library里面收录了近千万本电子书籍,需求量大。2.苦瓜书盘没有广告,不需要账号注册,使用起来非常简单,直接搜索预览下载即可。3.鸠摩搜书整体风格简洁清晰,书籍资源丰富。4.亚马逊图书书籍...

最好免费观看高清电影(播放免费的最好看的电影)

在目前的网上选择中,IMDb(互联网电影数据库)被认为是最全的电影网站之一。这个网站提供了各种类型的电影和电视节目的海量信息,包括剧情介绍、演员表、评价、评论等。其还提供了有关电影制作背后的详细信息,...

孤单枪手2简体中文版(孤单枪手2简体中文版官方下载)

要将《孤胆枪手2》游戏的征兵秘籍切换为中文,您可以按照以下步骤进行操作:首先,打开游戏设置选项,通常可以在游戏主菜单或游戏内部找到。然后,寻找语言选项或界面选项,点击进入。在语言选项中,选择中文作为游...

取消回复欢迎 发表评论: