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

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

off999 2024-09-18 22:40 16 浏览 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

相关推荐

python gui编程框架推荐以及介绍(python gui开发)

Python的GUI编程框架有很多,这里为您推荐几个常用且功能强大的框架:Tkinter:Tkinter是Python的标准GUI库,它是Python内置的模块,无需额外安装。它使用简单,功能较为基础...

python自动化框架学习-pyautogui(python接口自动化框架)

一、适用平台:PC(windows和mac均可用)二、下载安装:推荐使用命令行下载(因为会自动安装依赖库):pipinstallPyAutoGUI1该框架的依赖库还是蛮多的,第一次用的同学耐心等...

Python 失宠!Hugging Face 用 Rust 新写了一个 ML框架,现已低调开源

大数据文摘受权转载自AI前线整理|褚杏娟近期,HuggingFace低调开源了一个重磅ML框架:Candle。Candle一改机器学习惯用Python的做法,而是Rust编写,重...

Flask轻量级框架 web开发原来可以这么可爱呀~(建议收藏)

Flask轻量级框架web开发原来可以这么可爱呀大家好呀~今天让我们一起来学习一个超级可爱又实用的PythonWeb框架——Flask!作为一个轻量级的Web框架,Flask就像是一个小巧精致的工...

Python3使用diagrams生成架构图(python架构设计)

目录技术背景diagrams的安装基础逻辑关系图组件簇的定义总结概要参考链接技术背景对于一个架构师或者任何一个软件工程师而言,绘制架构图都是一个比较值得学习的技能。这就像我们学习的时候整理的一些Xmi...

几个高性能Python网络框架,高效实现网络应用

Python作为一种广泛使用的编程语言,其简洁易读的语法和强大的生态系统,使得它在Web开发领域占据重要位置。高性能的网络框架是构建高效网络应用的关键因素之一。本文将介绍几个高性能的Python网络框...

Web开发人员的十佳Python框架(python最好的web框架)

Python是一种面向对象、解释型计算机程序设计语言。除了语言本身的设计目的之外,Python的标准库也是值得大家称赞的,同时Python还自带服务器。其它方面,Python拥有足够多的免费数据函数库...

Diagram as Code:用python代码生成架构图

工作中常需要画系统架构图,通常的方法是通过visio、processon、draw.io之类的软件,但是今天介绍的这个软件Diagrams,可以通过写Python代码完成架构图绘制,确实很co...

分享一个2022年火遍全网的Python框架

作者:俊欣来源:关于数据分析与可视化最近Python圈子当中出来一个非常火爆的框架PyScript,该框架可以在浏览器中运行Python程序,只需要在HTML程序中添加一些Python代码即可实现。该...

10个用于Web开发的最好 Python 框架

Python是一门动态、面向对象语言。其最初就是作为一门面向对象语言设计的,并且在后期又加入了一些更高级的特性。除了语言本身的设计目的之外,Python标准库也是值得大家称赞的,Python甚至还...

使用 Python 将 Google 表格变成您自己的数据库

图片来自Shutterstock,获得FrankAndrade的许可您知道Google表格可以用作轻量级数据库吗?GoogleSheets是一个基于云的电子表格应用程序,可以像大多数数据库管...

牛掰!用Python处理Excel的14个常用操作总结!

自从学了Python后就逼迫用Python来处理Excel,所有操作用Python实现。目的是巩固Python,与增强数据处理能力。这也是我写这篇文章的初衷。废话不说了,直接进入正题。数据是网上找到的...

将python打包成exe的方式(将python文件打包成exe可运行文件)

客户端应用程序往往需要运行Python脚本,这对于那些不熟悉Python语言的用户来说可能会带来一定的困扰。幸运的是,Python拥有一些第三方模块,可以将这些脚本转换成可执行的.exe...

对比Excel学Python第1练:既有Excel,何用Python?

背景之前发的文章开头都是“Python数据分析……”,使得很多伙伴以为我是专门分享Python的,但我的本意并非如此,我的重点还是会放到“数据分析”上,毕竟,Python只是一种工具而已。现在网上可以...

高效办公:Python处理excel文件,摆脱无效办公

一、Python处理excel文件1.两个头文件importxlrdimportxlwt其中xlrd模块实现对excel文件内容读取,xlwt模块实现对excel文件的写入。2.读取exce...

取消回复欢迎 发表评论: