gooderp18绿色标准版
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1873 satır
183KB

  1. <!DOCTYPE html>
  2. <html lang="en" data-content_root="../">
  3. <head>
  4. <meta charset="utf-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta name="viewport" content="width=device-width, initial-scale=1" />
  6. <meta property="og:title" content="Enum HOWTO" />
  7. <meta property="og:type" content="website" />
  8. <meta property="og:url" content="https://docs.python.org/3/howto/enum.html" />
  9. <meta property="og:site_name" content="Python documentation" />
  10. <meta property="og:description" content="An Enum is a set of symbolic names bound to unique values. They are similar to global variables, but they offer a more useful repr(), grouping, type-safety, and a few other features. They are most ..." />
  11. <meta property="og:image" content="https://docs.python.org/3/_static/og-image.png" />
  12. <meta property="og:image:alt" content="Python documentation" />
  13. <meta name="description" content="An Enum is a set of symbolic names bound to unique values. They are similar to global variables, but they offer a more useful repr(), grouping, type-safety, and a few other features. They are most ..." />
  14. <meta property="og:image:width" content="200" />
  15. <meta property="og:image:height" content="200" />
  16. <meta name="theme-color" content="#3776ab" />
  17. <title>Enum HOWTO &#8212; Python 3.12.3 documentation</title><meta name="viewport" content="width=device-width, initial-scale=1.0">
  18. <link rel="stylesheet" type="text/css" href="../_static/pygments.css?v=80d5e7a1" />
  19. <link rel="stylesheet" type="text/css" href="../_static/pydoctheme.css?v=bb723527" />
  20. <link id="pygments_dark_css" media="(prefers-color-scheme: dark)" rel="stylesheet" type="text/css" href="../_static/pygments_dark.css?v=b20cc3f5" />
  21. <script src="../_static/documentation_options.js?v=2c828074"></script>
  22. <script src="../_static/doctools.js?v=888ff710"></script>
  23. <script src="../_static/sphinx_highlight.js?v=dc90522c"></script>
  24. <script src="../_static/sidebar.js"></script>
  25. <link rel="search" type="application/opensearchdescription+xml"
  26. title="Search within Python 3.12.3 documentation"
  27. href="../_static/opensearch.xml"/>
  28. <link rel="author" title="About these documents" href="../about.html" />
  29. <link rel="index" title="Index" href="../genindex.html" />
  30. <link rel="search" title="Search" href="../search.html" />
  31. <link rel="copyright" title="Copyright" href="../copyright.html" />
  32. <link rel="next" title="Functional Programming HOWTO" href="functional.html" />
  33. <link rel="prev" title="Debugging C API extensions and CPython Internals with GDB" href="gdb_helpers.html" />
  34. <link rel="canonical" href="https://docs.python.org/3/howto/enum.html" />
  35. <style>
  36. @media only screen {
  37. table.full-width-table {
  38. width: 100%;
  39. }
  40. }
  41. </style>
  42. <link rel="stylesheet" href="../_static/pydoctheme_dark.css" media="(prefers-color-scheme: dark)" id="pydoctheme_dark_css">
  43. <link rel="shortcut icon" type="image/png" href="../_static/py.svg" />
  44. <script type="text/javascript" src="../_static/copybutton.js"></script>
  45. <script type="text/javascript" src="../_static/menu.js"></script>
  46. <script type="text/javascript" src="../_static/search-focus.js"></script>
  47. <script type="text/javascript" src="../_static/themetoggle.js"></script>
  48. </head>
  49. <body>
  50. <div class="mobile-nav">
  51. <input type="checkbox" id="menuToggler" class="toggler__input" aria-controls="navigation"
  52. aria-pressed="false" aria-expanded="false" role="button" aria-label="Menu" />
  53. <nav class="nav-content" role="navigation">
  54. <label for="menuToggler" class="toggler__label">
  55. <span></span>
  56. </label>
  57. <span class="nav-items-wrapper">
  58. <a href="https://www.python.org/" class="nav-logo">
  59. <img src="../_static/py.svg" alt="Python logo"/>
  60. </a>
  61. <span class="version_switcher_placeholder"></span>
  62. <form role="search" class="search" action="../search.html" method="get">
  63. <svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 24 24" class="search-icon">
  64. <path fill-rule="nonzero" fill="currentColor" d="M15.5 14h-.79l-.28-.27a6.5 6.5 0 001.48-5.34c-.47-2.78-2.79-5-5.59-5.34a6.505 6.505 0 00-7.27 7.27c.34 2.8 2.56 5.12 5.34 5.59a6.5 6.5 0 005.34-1.48l.27.28v.79l4.25 4.25c.41.41 1.08.41 1.49 0 .41-.41.41-1.08 0-1.49L15.5 14zm-6 0C7.01 14 5 11.99 5 9.5S7.01 5 9.5 5 14 7.01 14 9.5 11.99 14 9.5 14z"></path>
  65. </svg>
  66. <input placeholder="Quick search" aria-label="Quick search" type="search" name="q" />
  67. <input type="submit" value="Go"/>
  68. </form>
  69. </span>
  70. </nav>
  71. <div class="menu-wrapper">
  72. <nav class="menu" role="navigation" aria-label="main navigation">
  73. <div class="language_switcher_placeholder"></div>
  74. <label class="theme-selector-label">
  75. Theme
  76. <select class="theme-selector" oninput="activateTheme(this.value)">
  77. <option value="auto" selected>Auto</option>
  78. <option value="light">Light</option>
  79. <option value="dark">Dark</option>
  80. </select>
  81. </label>
  82. <div>
  83. <h3><a href="../contents.html">Table of Contents</a></h3>
  84. <ul>
  85. <li><a class="reference internal" href="#">Enum HOWTO</a><ul>
  86. <li><a class="reference internal" href="#programmatic-access-to-enumeration-members-and-their-attributes">Programmatic access to enumeration members and their attributes</a></li>
  87. <li><a class="reference internal" href="#duplicating-enum-members-and-values">Duplicating enum members and values</a></li>
  88. <li><a class="reference internal" href="#ensuring-unique-enumeration-values">Ensuring unique enumeration values</a></li>
  89. <li><a class="reference internal" href="#using-automatic-values">Using automatic values</a></li>
  90. <li><a class="reference internal" href="#iteration">Iteration</a></li>
  91. <li><a class="reference internal" href="#comparisons">Comparisons</a></li>
  92. <li><a class="reference internal" href="#allowed-members-and-attributes-of-enumerations">Allowed members and attributes of enumerations</a></li>
  93. <li><a class="reference internal" href="#restricted-enum-subclassing">Restricted Enum subclassing</a></li>
  94. <li><a class="reference internal" href="#dataclass-support">Dataclass support</a></li>
  95. <li><a class="reference internal" href="#pickling">Pickling</a></li>
  96. <li><a class="reference internal" href="#functional-api">Functional API</a></li>
  97. <li><a class="reference internal" href="#derived-enumerations">Derived Enumerations</a><ul>
  98. <li><a class="reference internal" href="#intenum">IntEnum</a></li>
  99. <li><a class="reference internal" href="#strenum">StrEnum</a></li>
  100. <li><a class="reference internal" href="#intflag">IntFlag</a></li>
  101. <li><a class="reference internal" href="#flag">Flag</a></li>
  102. <li><a class="reference internal" href="#others">Others</a></li>
  103. </ul>
  104. </li>
  105. <li><a class="reference internal" href="#when-to-use-new-vs-init">When to use <code class="xref py py-meth docutils literal notranslate"><span class="pre">__new__()</span></code> vs. <code class="xref py py-meth docutils literal notranslate"><span class="pre">__init__()</span></code></a><ul>
  106. <li><a class="reference internal" href="#finer-points">Finer Points</a><ul>
  107. <li><a class="reference internal" href="#supported-dunder-names">Supported <code class="docutils literal notranslate"><span class="pre">__dunder__</span></code> names</a></li>
  108. <li><a class="reference internal" href="#supported-sunder-names">Supported <code class="docutils literal notranslate"><span class="pre">_sunder_</span></code> names</a></li>
  109. <li><a class="reference internal" href="#private-names">_Private__names</a></li>
  110. <li><a class="reference internal" href="#enum-member-type"><code class="docutils literal notranslate"><span class="pre">Enum</span></code> member type</a></li>
  111. <li><a class="reference internal" href="#creating-members-that-are-mixed-with-other-data-types">Creating members that are mixed with other data types</a></li>
  112. <li><a class="reference internal" href="#boolean-value-of-enum-classes-and-members">Boolean value of <code class="docutils literal notranslate"><span class="pre">Enum</span></code> classes and members</a></li>
  113. <li><a class="reference internal" href="#enum-classes-with-methods"><code class="docutils literal notranslate"><span class="pre">Enum</span></code> classes with methods</a></li>
  114. <li><a class="reference internal" href="#combining-members-of-flag">Combining members of <code class="docutils literal notranslate"><span class="pre">Flag</span></code></a></li>
  115. <li><a class="reference internal" href="#flag-and-intflag-minutia"><code class="docutils literal notranslate"><span class="pre">Flag</span></code> and <code class="docutils literal notranslate"><span class="pre">IntFlag</span></code> minutia</a></li>
  116. </ul>
  117. </li>
  118. </ul>
  119. </li>
  120. <li><a class="reference internal" href="#how-are-enums-and-flags-different">How are Enums and Flags different?</a><ul>
  121. <li><a class="reference internal" href="#enum-classes">Enum Classes</a></li>
  122. <li><a class="reference internal" href="#flag-classes">Flag Classes</a></li>
  123. <li><a class="reference internal" href="#enum-members-aka-instances">Enum Members (aka instances)</a></li>
  124. <li><a class="reference internal" href="#flag-members">Flag Members</a></li>
  125. </ul>
  126. </li>
  127. <li><a class="reference internal" href="#enum-cookbook">Enum Cookbook</a><ul>
  128. <li><a class="reference internal" href="#omitting-values">Omitting values</a><ul>
  129. <li><a class="reference internal" href="#using-auto">Using <code class="xref py py-class docutils literal notranslate"><span class="pre">auto</span></code></a></li>
  130. <li><a class="reference internal" href="#using-object">Using <code class="xref py py-class docutils literal notranslate"><span class="pre">object</span></code></a></li>
  131. <li><a class="reference internal" href="#using-a-descriptive-string">Using a descriptive string</a></li>
  132. <li><a class="reference internal" href="#using-a-custom-new">Using a custom <code class="xref py py-meth docutils literal notranslate"><span class="pre">__new__()</span></code></a></li>
  133. </ul>
  134. </li>
  135. <li><a class="reference internal" href="#orderedenum">OrderedEnum</a></li>
  136. <li><a class="reference internal" href="#duplicatefreeenum">DuplicateFreeEnum</a></li>
  137. <li><a class="reference internal" href="#planet">Planet</a></li>
  138. <li><a class="reference internal" href="#timeperiod">TimePeriod</a></li>
  139. </ul>
  140. </li>
  141. <li><a class="reference internal" href="#subclassing-enumtype">Subclassing EnumType</a></li>
  142. </ul>
  143. </li>
  144. </ul>
  145. </div>
  146. <div>
  147. <h4>Previous topic</h4>
  148. <p class="topless"><a href="gdb_helpers.html"
  149. title="previous chapter">Debugging C API extensions and CPython Internals with GDB</a></p>
  150. </div>
  151. <div>
  152. <h4>Next topic</h4>
  153. <p class="topless"><a href="functional.html"
  154. title="next chapter">Functional Programming HOWTO</a></p>
  155. </div>
  156. <div role="note" aria-label="source link">
  157. <h3>This Page</h3>
  158. <ul class="this-page-menu">
  159. <li><a href="../bugs.html">Report a Bug</a></li>
  160. <li>
  161. <a href="https://github.com/python/cpython/blob/main/Doc/howto/enum.rst"
  162. rel="nofollow">Show Source
  163. </a>
  164. </li>
  165. </ul>
  166. </div>
  167. </nav>
  168. </div>
  169. </div>
  170. <div class="related" role="navigation" aria-label="related navigation">
  171. <h3>Navigation</h3>
  172. <ul>
  173. <li class="right" style="margin-right: 10px">
  174. <a href="../genindex.html" title="General Index"
  175. accesskey="I">index</a></li>
  176. <li class="right" >
  177. <a href="../py-modindex.html" title="Python Module Index"
  178. >modules</a> |</li>
  179. <li class="right" >
  180. <a href="functional.html" title="Functional Programming HOWTO"
  181. accesskey="N">next</a> |</li>
  182. <li class="right" >
  183. <a href="gdb_helpers.html" title="Debugging C API extensions and CPython Internals with GDB"
  184. accesskey="P">previous</a> |</li>
  185. <li><img src="../_static/py.svg" alt="Python logo" style="vertical-align: middle; margin-top: -1px"/></li>
  186. <li><a href="https://www.python.org/">Python</a> &#187;</li>
  187. <li class="switchers">
  188. <div class="language_switcher_placeholder"></div>
  189. <div class="version_switcher_placeholder"></div>
  190. </li>
  191. <li>
  192. </li>
  193. <li id="cpython-language-and-version">
  194. <a href="../index.html">3.12.3 Documentation</a> &#187;
  195. </li>
  196. <li class="nav-item nav-item-1"><a href="index.html" accesskey="U">Python HOWTOs</a> &#187;</li>
  197. <li class="nav-item nav-item-this"><a href="">Enum HOWTO</a></li>
  198. <li class="right">
  199. <div class="inline-search" role="search">
  200. <form class="inline-search" action="../search.html" method="get">
  201. <input placeholder="Quick search" aria-label="Quick search" type="search" name="q" id="search-box" />
  202. <input type="submit" value="Go" />
  203. </form>
  204. </div>
  205. |
  206. </li>
  207. <li class="right">
  208. <label class="theme-selector-label">
  209. Theme
  210. <select class="theme-selector" oninput="activateTheme(this.value)">
  211. <option value="auto" selected>Auto</option>
  212. <option value="light">Light</option>
  213. <option value="dark">Dark</option>
  214. </select>
  215. </label> |</li>
  216. </ul>
  217. </div>
  218. <div class="document">
  219. <div class="documentwrapper">
  220. <div class="bodywrapper">
  221. <div class="body" role="main">
  222. <section id="enum-howto">
  223. <h1>Enum HOWTO<a class="headerlink" href="#enum-howto" title="Link to this heading">¶</a></h1>
  224. <p id="enum-basic-tutorial">An <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> is a set of symbolic names bound to unique values. They are
  225. similar to global variables, but they offer a more useful <a class="reference internal" href="../library/functions.html#repr" title="repr"><code class="xref py py-func docutils literal notranslate"><span class="pre">repr()</span></code></a>,
  226. grouping, type-safety, and a few other features.</p>
  227. <p>They are most useful when you have a variable that can take one of a limited
  228. selection of values. For example, the days of the week:</p>
  229. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="kn">from</span> <span class="nn">enum</span> <span class="kn">import</span> <span class="n">Enum</span>
  230. <span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Weekday</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  231. <span class="gp">... </span> <span class="n">MONDAY</span> <span class="o">=</span> <span class="mi">1</span>
  232. <span class="gp">... </span> <span class="n">TUESDAY</span> <span class="o">=</span> <span class="mi">2</span>
  233. <span class="gp">... </span> <span class="n">WEDNESDAY</span> <span class="o">=</span> <span class="mi">3</span>
  234. <span class="gp">... </span> <span class="n">THURSDAY</span> <span class="o">=</span> <span class="mi">4</span>
  235. <span class="gp">... </span> <span class="n">FRIDAY</span> <span class="o">=</span> <span class="mi">5</span>
  236. <span class="gp">... </span> <span class="n">SATURDAY</span> <span class="o">=</span> <span class="mi">6</span>
  237. <span class="gp">... </span> <span class="n">SUNDAY</span> <span class="o">=</span> <span class="mi">7</span>
  238. </pre></div>
  239. </div>
  240. <p>Or perhaps the RGB primary colors:</p>
  241. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="kn">from</span> <span class="nn">enum</span> <span class="kn">import</span> <span class="n">Enum</span>
  242. <span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Color</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  243. <span class="gp">... </span> <span class="n">RED</span> <span class="o">=</span> <span class="mi">1</span>
  244. <span class="gp">... </span> <span class="n">GREEN</span> <span class="o">=</span> <span class="mi">2</span>
  245. <span class="gp">... </span> <span class="n">BLUE</span> <span class="o">=</span> <span class="mi">3</span>
  246. </pre></div>
  247. </div>
  248. <p>As you can see, creating an <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> is as simple as writing a class that
  249. inherits from <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> itself.</p>
  250. <div class="admonition note">
  251. <p class="admonition-title">Note</p>
  252. <p>Case of Enum Members</p>
  253. <p>Because Enums are used to represent constants, and to help avoid issues
  254. with name clashes between mixin-class methods/attributes and enum names,
  255. we strongly recommend using UPPER_CASE names for members, and will be using
  256. that style in our examples.</p>
  257. </div>
  258. <p>Depending on the nature of the enum a member’s value may or may not be
  259. important, but either way that value can be used to get the corresponding
  260. member:</p>
  261. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">Weekday</span><span class="p">(</span><span class="mi">3</span><span class="p">)</span>
  262. <span class="go">&lt;Weekday.WEDNESDAY: 3&gt;</span>
  263. </pre></div>
  264. </div>
  265. <p>As you can see, the <code class="docutils literal notranslate"><span class="pre">repr()</span></code> of a member shows the enum name, the member name,
  266. and the value. The <code class="docutils literal notranslate"><span class="pre">str()</span></code> of a member shows only the enum name and member
  267. name:</p>
  268. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="nb">print</span><span class="p">(</span><span class="n">Weekday</span><span class="o">.</span><span class="n">THURSDAY</span><span class="p">)</span>
  269. <span class="go">Weekday.THURSDAY</span>
  270. </pre></div>
  271. </div>
  272. <p>The <em>type</em> of an enumeration member is the enum it belongs to:</p>
  273. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="nb">type</span><span class="p">(</span><span class="n">Weekday</span><span class="o">.</span><span class="n">MONDAY</span><span class="p">)</span>
  274. <span class="go">&lt;enum &#39;Weekday&#39;&gt;</span>
  275. <span class="gp">&gt;&gt;&gt; </span><span class="nb">isinstance</span><span class="p">(</span><span class="n">Weekday</span><span class="o">.</span><span class="n">FRIDAY</span><span class="p">,</span> <span class="n">Weekday</span><span class="p">)</span>
  276. <span class="go">True</span>
  277. </pre></div>
  278. </div>
  279. <p>Enum members have an attribute that contains just their <code class="xref py py-attr docutils literal notranslate"><span class="pre">name</span></code>:</p>
  280. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="nb">print</span><span class="p">(</span><span class="n">Weekday</span><span class="o">.</span><span class="n">TUESDAY</span><span class="o">.</span><span class="n">name</span><span class="p">)</span>
  281. <span class="go">TUESDAY</span>
  282. </pre></div>
  283. </div>
  284. <p>Likewise, they have an attribute for their <code class="xref py py-attr docutils literal notranslate"><span class="pre">value</span></code>:</p>
  285. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">Weekday</span><span class="o">.</span><span class="n">WEDNESDAY</span><span class="o">.</span><span class="n">value</span>
  286. <span class="go">3</span>
  287. </pre></div>
  288. </div>
  289. <p>Unlike many languages that treat enumerations solely as name/value pairs,
  290. Python Enums can have behavior added. For example, <a class="reference internal" href="../library/datetime.html#datetime.date" title="datetime.date"><code class="xref py py-class docutils literal notranslate"><span class="pre">datetime.date</span></code></a>
  291. has two methods for returning the weekday: <code class="xref py py-meth docutils literal notranslate"><span class="pre">weekday()</span></code> and <code class="xref py py-meth docutils literal notranslate"><span class="pre">isoweekday()</span></code>.
  292. The difference is that one of them counts from 0-6 and the other from 1-7.
  293. Rather than keep track of that ourselves we can add a method to the <code class="xref py py-class docutils literal notranslate"><span class="pre">Weekday</span></code>
  294. enum to extract the day from the <code class="xref py py-class docutils literal notranslate"><span class="pre">date</span></code> instance and return the matching
  295. enum member:</p>
  296. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="nd">@classmethod</span>
  297. <span class="k">def</span> <span class="nf">from_date</span><span class="p">(</span><span class="bp">cls</span><span class="p">,</span> <span class="n">date</span><span class="p">):</span>
  298. <span class="k">return</span> <span class="bp">cls</span><span class="p">(</span><span class="n">date</span><span class="o">.</span><span class="n">isoweekday</span><span class="p">())</span>
  299. </pre></div>
  300. </div>
  301. <p>The complete <code class="xref py py-class docutils literal notranslate"><span class="pre">Weekday</span></code> enum now looks like this:</p>
  302. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Weekday</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  303. <span class="gp">... </span> <span class="n">MONDAY</span> <span class="o">=</span> <span class="mi">1</span>
  304. <span class="gp">... </span> <span class="n">TUESDAY</span> <span class="o">=</span> <span class="mi">2</span>
  305. <span class="gp">... </span> <span class="n">WEDNESDAY</span> <span class="o">=</span> <span class="mi">3</span>
  306. <span class="gp">... </span> <span class="n">THURSDAY</span> <span class="o">=</span> <span class="mi">4</span>
  307. <span class="gp">... </span> <span class="n">FRIDAY</span> <span class="o">=</span> <span class="mi">5</span>
  308. <span class="gp">... </span> <span class="n">SATURDAY</span> <span class="o">=</span> <span class="mi">6</span>
  309. <span class="gp">... </span> <span class="n">SUNDAY</span> <span class="o">=</span> <span class="mi">7</span>
  310. <span class="gp">... </span> <span class="c1">#</span>
  311. <span class="gp">... </span> <span class="nd">@classmethod</span>
  312. <span class="gp">... </span> <span class="k">def</span> <span class="nf">from_date</span><span class="p">(</span><span class="bp">cls</span><span class="p">,</span> <span class="n">date</span><span class="p">):</span>
  313. <span class="gp">... </span> <span class="k">return</span> <span class="bp">cls</span><span class="p">(</span><span class="n">date</span><span class="o">.</span><span class="n">isoweekday</span><span class="p">())</span>
  314. </pre></div>
  315. </div>
  316. <p>Now we can find out what today is! Observe:</p>
  317. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="kn">from</span> <span class="nn">datetime</span> <span class="kn">import</span> <span class="n">date</span>
  318. <span class="gp">&gt;&gt;&gt; </span><span class="n">Weekday</span><span class="o">.</span><span class="n">from_date</span><span class="p">(</span><span class="n">date</span><span class="o">.</span><span class="n">today</span><span class="p">())</span>
  319. <span class="go">&lt;Weekday.TUESDAY: 2&gt;</span>
  320. </pre></div>
  321. </div>
  322. <p>Of course, if you’re reading this on some other day, you’ll see that day instead.</p>
  323. <p>This <code class="xref py py-class docutils literal notranslate"><span class="pre">Weekday</span></code> enum is great if our variable only needs one day, but
  324. what if we need several? Maybe we’re writing a function to plot chores during
  325. a week, and don’t want to use a <a class="reference internal" href="../library/stdtypes.html#list" title="list"><code class="xref py py-class docutils literal notranslate"><span class="pre">list</span></code></a> – we could use a different type
  326. of <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a>:</p>
  327. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="kn">from</span> <span class="nn">enum</span> <span class="kn">import</span> <span class="n">Flag</span>
  328. <span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Weekday</span><span class="p">(</span><span class="n">Flag</span><span class="p">):</span>
  329. <span class="gp">... </span> <span class="n">MONDAY</span> <span class="o">=</span> <span class="mi">1</span>
  330. <span class="gp">... </span> <span class="n">TUESDAY</span> <span class="o">=</span> <span class="mi">2</span>
  331. <span class="gp">... </span> <span class="n">WEDNESDAY</span> <span class="o">=</span> <span class="mi">4</span>
  332. <span class="gp">... </span> <span class="n">THURSDAY</span> <span class="o">=</span> <span class="mi">8</span>
  333. <span class="gp">... </span> <span class="n">FRIDAY</span> <span class="o">=</span> <span class="mi">16</span>
  334. <span class="gp">... </span> <span class="n">SATURDAY</span> <span class="o">=</span> <span class="mi">32</span>
  335. <span class="gp">... </span> <span class="n">SUNDAY</span> <span class="o">=</span> <span class="mi">64</span>
  336. </pre></div>
  337. </div>
  338. <p>We’ve changed two things: we’re inherited from <a class="reference internal" href="../library/enum.html#enum.Flag" title="enum.Flag"><code class="xref py py-class docutils literal notranslate"><span class="pre">Flag</span></code></a>, and the values are
  339. all powers of 2.</p>
  340. <p>Just like the original <code class="xref py py-class docutils literal notranslate"><span class="pre">Weekday</span></code> enum above, we can have a single selection:</p>
  341. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">first_week_day</span> <span class="o">=</span> <span class="n">Weekday</span><span class="o">.</span><span class="n">MONDAY</span>
  342. <span class="gp">&gt;&gt;&gt; </span><span class="n">first_week_day</span>
  343. <span class="go">&lt;Weekday.MONDAY: 1&gt;</span>
  344. </pre></div>
  345. </div>
  346. <p>But <a class="reference internal" href="../library/enum.html#enum.Flag" title="enum.Flag"><code class="xref py py-class docutils literal notranslate"><span class="pre">Flag</span></code></a> also allows us to combine several members into a single
  347. variable:</p>
  348. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">weekend</span> <span class="o">=</span> <span class="n">Weekday</span><span class="o">.</span><span class="n">SATURDAY</span> <span class="o">|</span> <span class="n">Weekday</span><span class="o">.</span><span class="n">SUNDAY</span>
  349. <span class="gp">&gt;&gt;&gt; </span><span class="n">weekend</span>
  350. <span class="go">&lt;Weekday.SATURDAY|SUNDAY: 96&gt;</span>
  351. </pre></div>
  352. </div>
  353. <p>You can even iterate over a <a class="reference internal" href="../library/enum.html#enum.Flag" title="enum.Flag"><code class="xref py py-class docutils literal notranslate"><span class="pre">Flag</span></code></a> variable:</p>
  354. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">for</span> <span class="n">day</span> <span class="ow">in</span> <span class="n">weekend</span><span class="p">:</span>
  355. <span class="gp">... </span> <span class="nb">print</span><span class="p">(</span><span class="n">day</span><span class="p">)</span>
  356. <span class="go">Weekday.SATURDAY</span>
  357. <span class="go">Weekday.SUNDAY</span>
  358. </pre></div>
  359. </div>
  360. <p>Okay, let’s get some chores set up:</p>
  361. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">chores_for_ethan</span> <span class="o">=</span> <span class="p">{</span>
  362. <span class="gp">... </span> <span class="s1">&#39;feed the cat&#39;</span><span class="p">:</span> <span class="n">Weekday</span><span class="o">.</span><span class="n">MONDAY</span> <span class="o">|</span> <span class="n">Weekday</span><span class="o">.</span><span class="n">WEDNESDAY</span> <span class="o">|</span> <span class="n">Weekday</span><span class="o">.</span><span class="n">FRIDAY</span><span class="p">,</span>
  363. <span class="gp">... </span> <span class="s1">&#39;do the dishes&#39;</span><span class="p">:</span> <span class="n">Weekday</span><span class="o">.</span><span class="n">TUESDAY</span> <span class="o">|</span> <span class="n">Weekday</span><span class="o">.</span><span class="n">THURSDAY</span><span class="p">,</span>
  364. <span class="gp">... </span> <span class="s1">&#39;answer SO questions&#39;</span><span class="p">:</span> <span class="n">Weekday</span><span class="o">.</span><span class="n">SATURDAY</span><span class="p">,</span>
  365. <span class="gp">... </span> <span class="p">}</span>
  366. </pre></div>
  367. </div>
  368. <p>And a function to display the chores for a given day:</p>
  369. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">def</span> <span class="nf">show_chores</span><span class="p">(</span><span class="n">chores</span><span class="p">,</span> <span class="n">day</span><span class="p">):</span>
  370. <span class="gp">... </span> <span class="k">for</span> <span class="n">chore</span><span class="p">,</span> <span class="n">days</span> <span class="ow">in</span> <span class="n">chores</span><span class="o">.</span><span class="n">items</span><span class="p">():</span>
  371. <span class="gp">... </span> <span class="k">if</span> <span class="n">day</span> <span class="ow">in</span> <span class="n">days</span><span class="p">:</span>
  372. <span class="gp">... </span> <span class="nb">print</span><span class="p">(</span><span class="n">chore</span><span class="p">)</span>
  373. <span class="gp">...</span>
  374. <span class="gp">&gt;&gt;&gt; </span><span class="n">show_chores</span><span class="p">(</span><span class="n">chores_for_ethan</span><span class="p">,</span> <span class="n">Weekday</span><span class="o">.</span><span class="n">SATURDAY</span><span class="p">)</span>
  375. <span class="go">answer SO questions</span>
  376. </pre></div>
  377. </div>
  378. <p>In cases where the actual values of the members do not matter, you can save
  379. yourself some work and use <a class="reference internal" href="../library/enum.html#enum.auto" title="enum.auto"><code class="xref py py-func docutils literal notranslate"><span class="pre">auto()</span></code></a> for the values:</p>
  380. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="kn">from</span> <span class="nn">enum</span> <span class="kn">import</span> <span class="n">auto</span>
  381. <span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Weekday</span><span class="p">(</span><span class="n">Flag</span><span class="p">):</span>
  382. <span class="gp">... </span> <span class="n">MONDAY</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  383. <span class="gp">... </span> <span class="n">TUESDAY</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  384. <span class="gp">... </span> <span class="n">WEDNESDAY</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  385. <span class="gp">... </span> <span class="n">THURSDAY</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  386. <span class="gp">... </span> <span class="n">FRIDAY</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  387. <span class="gp">... </span> <span class="n">SATURDAY</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  388. <span class="gp">... </span> <span class="n">SUNDAY</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  389. <span class="gp">... </span> <span class="n">WEEKEND</span> <span class="o">=</span> <span class="n">SATURDAY</span> <span class="o">|</span> <span class="n">SUNDAY</span>
  390. </pre></div>
  391. </div>
  392. <section id="programmatic-access-to-enumeration-members-and-their-attributes">
  393. <span id="enum-advanced-tutorial"></span><h2>Programmatic access to enumeration members and their attributes<a class="headerlink" href="#programmatic-access-to-enumeration-members-and-their-attributes" title="Link to this heading">¶</a></h2>
  394. <p>Sometimes it’s useful to access members in enumerations programmatically (i.e.
  395. situations where <code class="docutils literal notranslate"><span class="pre">Color.RED</span></code> won’t do because the exact color is not known
  396. at program-writing time). <code class="docutils literal notranslate"><span class="pre">Enum</span></code> allows such access:</p>
  397. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="p">(</span><span class="mi">1</span><span class="p">)</span>
  398. <span class="go">&lt;Color.RED: 1&gt;</span>
  399. <span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="p">(</span><span class="mi">3</span><span class="p">)</span>
  400. <span class="go">&lt;Color.BLUE: 3&gt;</span>
  401. </pre></div>
  402. </div>
  403. <p>If you want to access enum members by <em>name</em>, use item access:</p>
  404. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="p">[</span><span class="s1">&#39;RED&#39;</span><span class="p">]</span>
  405. <span class="go">&lt;Color.RED: 1&gt;</span>
  406. <span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="p">[</span><span class="s1">&#39;GREEN&#39;</span><span class="p">]</span>
  407. <span class="go">&lt;Color.GREEN: 2&gt;</span>
  408. </pre></div>
  409. </div>
  410. <p>If you have an enum member and need its <code class="xref py py-attr docutils literal notranslate"><span class="pre">name</span></code> or <code class="xref py py-attr docutils literal notranslate"><span class="pre">value</span></code>:</p>
  411. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">member</span> <span class="o">=</span> <span class="n">Color</span><span class="o">.</span><span class="n">RED</span>
  412. <span class="gp">&gt;&gt;&gt; </span><span class="n">member</span><span class="o">.</span><span class="n">name</span>
  413. <span class="go">&#39;RED&#39;</span>
  414. <span class="gp">&gt;&gt;&gt; </span><span class="n">member</span><span class="o">.</span><span class="n">value</span>
  415. <span class="go">1</span>
  416. </pre></div>
  417. </div>
  418. </section>
  419. <section id="duplicating-enum-members-and-values">
  420. <h2>Duplicating enum members and values<a class="headerlink" href="#duplicating-enum-members-and-values" title="Link to this heading">¶</a></h2>
  421. <p>Having two enum members with the same name is invalid:</p>
  422. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Shape</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  423. <span class="gp">... </span> <span class="n">SQUARE</span> <span class="o">=</span> <span class="mi">2</span>
  424. <span class="gp">... </span> <span class="n">SQUARE</span> <span class="o">=</span> <span class="mi">3</span>
  425. <span class="gp">...</span>
  426. <span class="gt">Traceback (most recent call last):</span>
  427. <span class="c">...</span>
  428. <span class="gr">TypeError</span>: <span class="n">&#39;SQUARE&#39; already defined as 2</span>
  429. </pre></div>
  430. </div>
  431. <p>However, an enum member can have other names associated with it. Given two
  432. entries <code class="docutils literal notranslate"><span class="pre">A</span></code> and <code class="docutils literal notranslate"><span class="pre">B</span></code> with the same value (and <code class="docutils literal notranslate"><span class="pre">A</span></code> defined first), <code class="docutils literal notranslate"><span class="pre">B</span></code>
  433. is an alias for the member <code class="docutils literal notranslate"><span class="pre">A</span></code>. By-value lookup of the value of <code class="docutils literal notranslate"><span class="pre">A</span></code> will
  434. return the member <code class="docutils literal notranslate"><span class="pre">A</span></code>. By-name lookup of <code class="docutils literal notranslate"><span class="pre">A</span></code> will return the member <code class="docutils literal notranslate"><span class="pre">A</span></code>.
  435. By-name lookup of <code class="docutils literal notranslate"><span class="pre">B</span></code> will also return the member <code class="docutils literal notranslate"><span class="pre">A</span></code>:</p>
  436. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Shape</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  437. <span class="gp">... </span> <span class="n">SQUARE</span> <span class="o">=</span> <span class="mi">2</span>
  438. <span class="gp">... </span> <span class="n">DIAMOND</span> <span class="o">=</span> <span class="mi">1</span>
  439. <span class="gp">... </span> <span class="n">CIRCLE</span> <span class="o">=</span> <span class="mi">3</span>
  440. <span class="gp">... </span> <span class="n">ALIAS_FOR_SQUARE</span> <span class="o">=</span> <span class="mi">2</span>
  441. <span class="gp">...</span>
  442. <span class="gp">&gt;&gt;&gt; </span><span class="n">Shape</span><span class="o">.</span><span class="n">SQUARE</span>
  443. <span class="go">&lt;Shape.SQUARE: 2&gt;</span>
  444. <span class="gp">&gt;&gt;&gt; </span><span class="n">Shape</span><span class="o">.</span><span class="n">ALIAS_FOR_SQUARE</span>
  445. <span class="go">&lt;Shape.SQUARE: 2&gt;</span>
  446. <span class="gp">&gt;&gt;&gt; </span><span class="n">Shape</span><span class="p">(</span><span class="mi">2</span><span class="p">)</span>
  447. <span class="go">&lt;Shape.SQUARE: 2&gt;</span>
  448. </pre></div>
  449. </div>
  450. <div class="admonition note">
  451. <p class="admonition-title">Note</p>
  452. <p>Attempting to create a member with the same name as an already
  453. defined attribute (another member, a method, etc.) or attempting to create
  454. an attribute with the same name as a member is not allowed.</p>
  455. </div>
  456. </section>
  457. <section id="ensuring-unique-enumeration-values">
  458. <h2>Ensuring unique enumeration values<a class="headerlink" href="#ensuring-unique-enumeration-values" title="Link to this heading">¶</a></h2>
  459. <p>By default, enumerations allow multiple names as aliases for the same value.
  460. When this behavior isn’t desired, you can use the <a class="reference internal" href="../library/enum.html#enum.unique" title="enum.unique"><code class="xref py py-func docutils literal notranslate"><span class="pre">unique()</span></code></a> decorator:</p>
  461. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="kn">from</span> <span class="nn">enum</span> <span class="kn">import</span> <span class="n">Enum</span><span class="p">,</span> <span class="n">unique</span>
  462. <span class="gp">&gt;&gt;&gt; </span><span class="nd">@unique</span>
  463. <span class="gp">... </span><span class="k">class</span> <span class="nc">Mistake</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  464. <span class="gp">... </span> <span class="n">ONE</span> <span class="o">=</span> <span class="mi">1</span>
  465. <span class="gp">... </span> <span class="n">TWO</span> <span class="o">=</span> <span class="mi">2</span>
  466. <span class="gp">... </span> <span class="n">THREE</span> <span class="o">=</span> <span class="mi">3</span>
  467. <span class="gp">... </span> <span class="n">FOUR</span> <span class="o">=</span> <span class="mi">3</span>
  468. <span class="gp">...</span>
  469. <span class="gt">Traceback (most recent call last):</span>
  470. <span class="c">...</span>
  471. <span class="gr">ValueError</span>: <span class="n">duplicate values found in &lt;enum &#39;Mistake&#39;&gt;: FOUR -&gt; THREE</span>
  472. </pre></div>
  473. </div>
  474. </section>
  475. <section id="using-automatic-values">
  476. <h2>Using automatic values<a class="headerlink" href="#using-automatic-values" title="Link to this heading">¶</a></h2>
  477. <p>If the exact value is unimportant you can use <a class="reference internal" href="../library/enum.html#enum.auto" title="enum.auto"><code class="xref py py-class docutils literal notranslate"><span class="pre">auto</span></code></a>:</p>
  478. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="kn">from</span> <span class="nn">enum</span> <span class="kn">import</span> <span class="n">Enum</span><span class="p">,</span> <span class="n">auto</span>
  479. <span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Color</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  480. <span class="gp">... </span> <span class="n">RED</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  481. <span class="gp">... </span> <span class="n">BLUE</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  482. <span class="gp">... </span> <span class="n">GREEN</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  483. <span class="gp">...</span>
  484. <span class="gp">&gt;&gt;&gt; </span><span class="p">[</span><span class="n">member</span><span class="o">.</span><span class="n">value</span> <span class="k">for</span> <span class="n">member</span> <span class="ow">in</span> <span class="n">Color</span><span class="p">]</span>
  485. <span class="go">[1, 2, 3]</span>
  486. </pre></div>
  487. </div>
  488. <p>The values are chosen by <code class="xref py py-func docutils literal notranslate"><span class="pre">_generate_next_value_()</span></code>, which can be
  489. overridden:</p>
  490. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">AutoName</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  491. <span class="gp">... </span> <span class="nd">@staticmethod</span>
  492. <span class="gp">... </span> <span class="k">def</span> <span class="nf">_generate_next_value_</span><span class="p">(</span><span class="n">name</span><span class="p">,</span> <span class="n">start</span><span class="p">,</span> <span class="n">count</span><span class="p">,</span> <span class="n">last_values</span><span class="p">):</span>
  493. <span class="gp">... </span> <span class="k">return</span> <span class="n">name</span>
  494. <span class="gp">...</span>
  495. <span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Ordinal</span><span class="p">(</span><span class="n">AutoName</span><span class="p">):</span>
  496. <span class="gp">... </span> <span class="n">NORTH</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  497. <span class="gp">... </span> <span class="n">SOUTH</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  498. <span class="gp">... </span> <span class="n">EAST</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  499. <span class="gp">... </span> <span class="n">WEST</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  500. <span class="gp">...</span>
  501. <span class="gp">&gt;&gt;&gt; </span><span class="p">[</span><span class="n">member</span><span class="o">.</span><span class="n">value</span> <span class="k">for</span> <span class="n">member</span> <span class="ow">in</span> <span class="n">Ordinal</span><span class="p">]</span>
  502. <span class="go">[&#39;NORTH&#39;, &#39;SOUTH&#39;, &#39;EAST&#39;, &#39;WEST&#39;]</span>
  503. </pre></div>
  504. </div>
  505. <div class="admonition note">
  506. <p class="admonition-title">Note</p>
  507. <p>The <code class="xref py py-meth docutils literal notranslate"><span class="pre">_generate_next_value_()</span></code> method must be defined before any members.</p>
  508. </div>
  509. </section>
  510. <section id="iteration">
  511. <h2>Iteration<a class="headerlink" href="#iteration" title="Link to this heading">¶</a></h2>
  512. <p>Iterating over the members of an enum does not provide the aliases:</p>
  513. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="nb">list</span><span class="p">(</span><span class="n">Shape</span><span class="p">)</span>
  514. <span class="go">[&lt;Shape.SQUARE: 2&gt;, &lt;Shape.DIAMOND: 1&gt;, &lt;Shape.CIRCLE: 3&gt;]</span>
  515. <span class="gp">&gt;&gt;&gt; </span><span class="nb">list</span><span class="p">(</span><span class="n">Weekday</span><span class="p">)</span>
  516. <span class="go">[&lt;Weekday.MONDAY: 1&gt;, &lt;Weekday.TUESDAY: 2&gt;, &lt;Weekday.WEDNESDAY: 4&gt;, &lt;Weekday.THURSDAY: 8&gt;, &lt;Weekday.FRIDAY: 16&gt;, &lt;Weekday.SATURDAY: 32&gt;, &lt;Weekday.SUNDAY: 64&gt;]</span>
  517. </pre></div>
  518. </div>
  519. <p>Note that the aliases <code class="docutils literal notranslate"><span class="pre">Shape.ALIAS_FOR_SQUARE</span></code> and <code class="docutils literal notranslate"><span class="pre">Weekday.WEEKEND</span></code> aren’t shown.</p>
  520. <p>The special attribute <code class="docutils literal notranslate"><span class="pre">__members__</span></code> is a read-only ordered mapping of names
  521. to members. It includes all names defined in the enumeration, including the
  522. aliases:</p>
  523. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">for</span> <span class="n">name</span><span class="p">,</span> <span class="n">member</span> <span class="ow">in</span> <span class="n">Shape</span><span class="o">.</span><span class="n">__members__</span><span class="o">.</span><span class="n">items</span><span class="p">():</span>
  524. <span class="gp">... </span> <span class="n">name</span><span class="p">,</span> <span class="n">member</span>
  525. <span class="gp">...</span>
  526. <span class="go">(&#39;SQUARE&#39;, &lt;Shape.SQUARE: 2&gt;)</span>
  527. <span class="go">(&#39;DIAMOND&#39;, &lt;Shape.DIAMOND: 1&gt;)</span>
  528. <span class="go">(&#39;CIRCLE&#39;, &lt;Shape.CIRCLE: 3&gt;)</span>
  529. <span class="go">(&#39;ALIAS_FOR_SQUARE&#39;, &lt;Shape.SQUARE: 2&gt;)</span>
  530. </pre></div>
  531. </div>
  532. <p>The <code class="docutils literal notranslate"><span class="pre">__members__</span></code> attribute can be used for detailed programmatic access to
  533. the enumeration members. For example, finding all the aliases:</p>
  534. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="p">[</span><span class="n">name</span> <span class="k">for</span> <span class="n">name</span><span class="p">,</span> <span class="n">member</span> <span class="ow">in</span> <span class="n">Shape</span><span class="o">.</span><span class="n">__members__</span><span class="o">.</span><span class="n">items</span><span class="p">()</span> <span class="k">if</span> <span class="n">member</span><span class="o">.</span><span class="n">name</span> <span class="o">!=</span> <span class="n">name</span><span class="p">]</span>
  535. <span class="go">[&#39;ALIAS_FOR_SQUARE&#39;]</span>
  536. </pre></div>
  537. </div>
  538. <div class="admonition note">
  539. <p class="admonition-title">Note</p>
  540. <p>Aliases for flags include values with multiple flags set, such as <code class="docutils literal notranslate"><span class="pre">3</span></code>,
  541. and no flags set, i.e. <code class="docutils literal notranslate"><span class="pre">0</span></code>.</p>
  542. </div>
  543. </section>
  544. <section id="comparisons">
  545. <h2>Comparisons<a class="headerlink" href="#comparisons" title="Link to this heading">¶</a></h2>
  546. <p>Enumeration members are compared by identity:</p>
  547. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">RED</span> <span class="ow">is</span> <span class="n">Color</span><span class="o">.</span><span class="n">RED</span>
  548. <span class="go">True</span>
  549. <span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">RED</span> <span class="ow">is</span> <span class="n">Color</span><span class="o">.</span><span class="n">BLUE</span>
  550. <span class="go">False</span>
  551. <span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">RED</span> <span class="ow">is</span> <span class="ow">not</span> <span class="n">Color</span><span class="o">.</span><span class="n">BLUE</span>
  552. <span class="go">True</span>
  553. </pre></div>
  554. </div>
  555. <p>Ordered comparisons between enumeration values are <em>not</em> supported. Enum
  556. members are not integers (but see <a class="reference internal" href="#intenum">IntEnum</a> below):</p>
  557. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">RED</span> <span class="o">&lt;</span> <span class="n">Color</span><span class="o">.</span><span class="n">BLUE</span>
  558. <span class="gt">Traceback (most recent call last):</span>
  559. File <span class="nb">&quot;&lt;stdin&gt;&quot;</span>, line <span class="m">1</span>, in <span class="n">&lt;module&gt;</span>
  560. <span class="gr">TypeError</span>: <span class="n">&#39;&lt;&#39; not supported between instances of &#39;Color&#39; and &#39;Color&#39;</span>
  561. </pre></div>
  562. </div>
  563. <p>Equality comparisons are defined though:</p>
  564. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">BLUE</span> <span class="o">==</span> <span class="n">Color</span><span class="o">.</span><span class="n">RED</span>
  565. <span class="go">False</span>
  566. <span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">BLUE</span> <span class="o">!=</span> <span class="n">Color</span><span class="o">.</span><span class="n">RED</span>
  567. <span class="go">True</span>
  568. <span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">BLUE</span> <span class="o">==</span> <span class="n">Color</span><span class="o">.</span><span class="n">BLUE</span>
  569. <span class="go">True</span>
  570. </pre></div>
  571. </div>
  572. <p>Comparisons against non-enumeration values will always compare not equal
  573. (again, <a class="reference internal" href="../library/enum.html#enum.IntEnum" title="enum.IntEnum"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntEnum</span></code></a> was explicitly designed to behave differently, see
  574. below):</p>
  575. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">BLUE</span> <span class="o">==</span> <span class="mi">2</span>
  576. <span class="go">False</span>
  577. </pre></div>
  578. </div>
  579. <div class="admonition warning">
  580. <p class="admonition-title">Warning</p>
  581. <p>It is possible to reload modules – if a reloaded module contains
  582. enums, they will be recreated, and the new members may not
  583. compare identical/equal to the original members.</p>
  584. </div>
  585. </section>
  586. <section id="allowed-members-and-attributes-of-enumerations">
  587. <h2>Allowed members and attributes of enumerations<a class="headerlink" href="#allowed-members-and-attributes-of-enumerations" title="Link to this heading">¶</a></h2>
  588. <p>Most of the examples above use integers for enumeration values. Using integers
  589. is short and handy (and provided by default by the <a class="reference internal" href="#functional-api">Functional API</a>), but not
  590. strictly enforced. In the vast majority of use-cases, one doesn’t care what
  591. the actual value of an enumeration is. But if the value <em>is</em> important,
  592. enumerations can have arbitrary values.</p>
  593. <p>Enumerations are Python classes, and can have methods and special methods as
  594. usual. If we have this enumeration:</p>
  595. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Mood</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  596. <span class="gp">... </span> <span class="n">FUNKY</span> <span class="o">=</span> <span class="mi">1</span>
  597. <span class="gp">... </span> <span class="n">HAPPY</span> <span class="o">=</span> <span class="mi">3</span>
  598. <span class="gp">...</span>
  599. <span class="gp">... </span> <span class="k">def</span> <span class="nf">describe</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
  600. <span class="gp">... </span> <span class="c1"># self is the member here</span>
  601. <span class="gp">... </span> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">name</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">value</span>
  602. <span class="gp">...</span>
  603. <span class="gp">... </span> <span class="k">def</span> <span class="fm">__str__</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
  604. <span class="gp">... </span> <span class="k">return</span> <span class="s1">&#39;my custom str! </span><span class="si">{0}</span><span class="s1">&#39;</span><span class="o">.</span><span class="n">format</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">value</span><span class="p">)</span>
  605. <span class="gp">...</span>
  606. <span class="gp">... </span> <span class="nd">@classmethod</span>
  607. <span class="gp">... </span> <span class="k">def</span> <span class="nf">favorite_mood</span><span class="p">(</span><span class="bp">cls</span><span class="p">):</span>
  608. <span class="gp">... </span> <span class="c1"># cls here is the enumeration</span>
  609. <span class="gp">... </span> <span class="k">return</span> <span class="bp">cls</span><span class="o">.</span><span class="n">HAPPY</span>
  610. <span class="gp">...</span>
  611. </pre></div>
  612. </div>
  613. <p>Then:</p>
  614. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">Mood</span><span class="o">.</span><span class="n">favorite_mood</span><span class="p">()</span>
  615. <span class="go">&lt;Mood.HAPPY: 3&gt;</span>
  616. <span class="gp">&gt;&gt;&gt; </span><span class="n">Mood</span><span class="o">.</span><span class="n">HAPPY</span><span class="o">.</span><span class="n">describe</span><span class="p">()</span>
  617. <span class="go">(&#39;HAPPY&#39;, 3)</span>
  618. <span class="gp">&gt;&gt;&gt; </span><span class="nb">str</span><span class="p">(</span><span class="n">Mood</span><span class="o">.</span><span class="n">FUNKY</span><span class="p">)</span>
  619. <span class="go">&#39;my custom str! 1&#39;</span>
  620. </pre></div>
  621. </div>
  622. <p>The rules for what is allowed are as follows: names that start and end with
  623. a single underscore are reserved by enum and cannot be used; all other
  624. attributes defined within an enumeration will become members of this
  625. enumeration, with the exception of special methods (<code class="xref py py-meth docutils literal notranslate"><span class="pre">__str__()</span></code>,
  626. <code class="xref py py-meth docutils literal notranslate"><span class="pre">__add__()</span></code>, etc.), descriptors (methods are also descriptors), and
  627. variable names listed in <code class="xref py py-attr docutils literal notranslate"><span class="pre">_ignore_</span></code>.</p>
  628. <p>Note: if your enumeration defines <code class="xref py py-meth docutils literal notranslate"><span class="pre">__new__()</span></code> and/or <code class="xref py py-meth docutils literal notranslate"><span class="pre">__init__()</span></code>,
  629. any value(s) given to the enum member will be passed into those methods.
  630. See <a class="reference internal" href="#planet">Planet</a> for an example.</p>
  631. <div class="admonition note">
  632. <p class="admonition-title">Note</p>
  633. <p>The <code class="xref py py-meth docutils literal notranslate"><span class="pre">__new__()</span></code> method, if defined, is used during creation of the Enum
  634. members; it is then replaced by Enum’s <code class="xref py py-meth docutils literal notranslate"><span class="pre">__new__()</span></code> which is used after
  635. class creation for lookup of existing members. See <a class="reference internal" href="#new-vs-init"><span class="std std-ref">When to use __new__() vs. __init__()</span></a> for
  636. more details.</p>
  637. </div>
  638. </section>
  639. <section id="restricted-enum-subclassing">
  640. <h2>Restricted Enum subclassing<a class="headerlink" href="#restricted-enum-subclassing" title="Link to this heading">¶</a></h2>
  641. <p>A new <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> class must have one base enum class, up to one concrete
  642. data type, and as many <a class="reference internal" href="../library/functions.html#object" title="object"><code class="xref py py-class docutils literal notranslate"><span class="pre">object</span></code></a>-based mixin classes as needed. The
  643. order of these base classes is:</p>
  644. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="k">class</span> <span class="nc">EnumName</span><span class="p">([</span><span class="n">mix</span><span class="o">-</span><span class="ow">in</span><span class="p">,</span> <span class="o">...</span><span class="p">,]</span> <span class="p">[</span><span class="n">data</span><span class="o">-</span><span class="nb">type</span><span class="p">,]</span> <span class="n">base</span><span class="o">-</span><span class="n">enum</span><span class="p">):</span>
  645. <span class="k">pass</span>
  646. </pre></div>
  647. </div>
  648. <p>Also, subclassing an enumeration is allowed only if the enumeration does not define
  649. any members. So this is forbidden:</p>
  650. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">MoreColor</span><span class="p">(</span><span class="n">Color</span><span class="p">):</span>
  651. <span class="gp">... </span> <span class="n">PINK</span> <span class="o">=</span> <span class="mi">17</span>
  652. <span class="gp">...</span>
  653. <span class="gt">Traceback (most recent call last):</span>
  654. <span class="c">...</span>
  655. <span class="gr">TypeError</span>: <span class="n">&lt;enum &#39;MoreColor&#39;&gt; cannot extend &lt;enum &#39;Color&#39;&gt;</span>
  656. </pre></div>
  657. </div>
  658. <p>But this is allowed:</p>
  659. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Foo</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  660. <span class="gp">... </span> <span class="k">def</span> <span class="nf">some_behavior</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
  661. <span class="gp">... </span> <span class="k">pass</span>
  662. <span class="gp">...</span>
  663. <span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Bar</span><span class="p">(</span><span class="n">Foo</span><span class="p">):</span>
  664. <span class="gp">... </span> <span class="n">HAPPY</span> <span class="o">=</span> <span class="mi">1</span>
  665. <span class="gp">... </span> <span class="n">SAD</span> <span class="o">=</span> <span class="mi">2</span>
  666. <span class="gp">...</span>
  667. </pre></div>
  668. </div>
  669. <p>Allowing subclassing of enums that define members would lead to a violation of
  670. some important invariants of types and instances. On the other hand, it makes
  671. sense to allow sharing some common behavior between a group of enumerations.
  672. (See <a class="reference internal" href="#orderedenum">OrderedEnum</a> for an example.)</p>
  673. </section>
  674. <section id="dataclass-support">
  675. <span id="enum-dataclass-support"></span><h2>Dataclass support<a class="headerlink" href="#dataclass-support" title="Link to this heading">¶</a></h2>
  676. <p>When inheriting from a <a class="reference internal" href="../library/dataclasses.html#dataclasses.dataclass" title="dataclasses.dataclass"><code class="xref py py-class docutils literal notranslate"><span class="pre">dataclass</span></code></a>,
  677. the <a class="reference internal" href="../library/enum.html#enum.Enum.__repr__" title="enum.Enum.__repr__"><code class="xref py py-meth docutils literal notranslate"><span class="pre">__repr__()</span></code></a> omits the inherited class’ name. For example:</p>
  678. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="kn">from</span> <span class="nn">dataclasses</span> <span class="kn">import</span> <span class="n">dataclass</span><span class="p">,</span> <span class="n">field</span>
  679. <span class="gp">&gt;&gt;&gt; </span><span class="nd">@dataclass</span>
  680. <span class="gp">... </span><span class="k">class</span> <span class="nc">CreatureDataMixin</span><span class="p">:</span>
  681. <span class="gp">... </span> <span class="n">size</span><span class="p">:</span> <span class="nb">str</span>
  682. <span class="gp">... </span> <span class="n">legs</span><span class="p">:</span> <span class="nb">int</span>
  683. <span class="gp">... </span> <span class="n">tail</span><span class="p">:</span> <span class="nb">bool</span> <span class="o">=</span> <span class="n">field</span><span class="p">(</span><span class="nb">repr</span><span class="o">=</span><span class="kc">False</span><span class="p">,</span> <span class="n">default</span><span class="o">=</span><span class="kc">True</span><span class="p">)</span>
  684. <span class="gp">...</span>
  685. <span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Creature</span><span class="p">(</span><span class="n">CreatureDataMixin</span><span class="p">,</span> <span class="n">Enum</span><span class="p">):</span>
  686. <span class="gp">... </span> <span class="n">BEETLE</span> <span class="o">=</span> <span class="s1">&#39;small&#39;</span><span class="p">,</span> <span class="mi">6</span>
  687. <span class="gp">... </span> <span class="n">DOG</span> <span class="o">=</span> <span class="s1">&#39;medium&#39;</span><span class="p">,</span> <span class="mi">4</span>
  688. <span class="gp">...</span>
  689. <span class="gp">&gt;&gt;&gt; </span><span class="n">Creature</span><span class="o">.</span><span class="n">DOG</span>
  690. <span class="go">&lt;Creature.DOG: size=&#39;medium&#39;, legs=4&gt;</span>
  691. </pre></div>
  692. </div>
  693. <p>Use the <code class="xref py py-func docutils literal notranslate"><span class="pre">dataclass()</span></code> argument <code class="docutils literal notranslate"><span class="pre">repr=False</span></code>
  694. to use the standard <a class="reference internal" href="../library/functions.html#repr" title="repr"><code class="xref py py-func docutils literal notranslate"><span class="pre">repr()</span></code></a>.</p>
  695. <div class="versionchanged">
  696. <p><span class="versionmodified changed">Changed in version 3.12: </span>Only the dataclass fields are shown in the value area, not the dataclass’
  697. name.</p>
  698. </div>
  699. </section>
  700. <section id="pickling">
  701. <h2>Pickling<a class="headerlink" href="#pickling" title="Link to this heading">¶</a></h2>
  702. <p>Enumerations can be pickled and unpickled:</p>
  703. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="kn">from</span> <span class="nn">test.test_enum</span> <span class="kn">import</span> <span class="n">Fruit</span>
  704. <span class="gp">&gt;&gt;&gt; </span><span class="kn">from</span> <span class="nn">pickle</span> <span class="kn">import</span> <span class="n">dumps</span><span class="p">,</span> <span class="n">loads</span>
  705. <span class="gp">&gt;&gt;&gt; </span><span class="n">Fruit</span><span class="o">.</span><span class="n">TOMATO</span> <span class="ow">is</span> <span class="n">loads</span><span class="p">(</span><span class="n">dumps</span><span class="p">(</span><span class="n">Fruit</span><span class="o">.</span><span class="n">TOMATO</span><span class="p">))</span>
  706. <span class="go">True</span>
  707. </pre></div>
  708. </div>
  709. <p>The usual restrictions for pickling apply: picklable enums must be defined in
  710. the top level of a module, since unpickling requires them to be importable
  711. from that module.</p>
  712. <div class="admonition note">
  713. <p class="admonition-title">Note</p>
  714. <p>With pickle protocol version 4 it is possible to easily pickle enums
  715. nested in other classes.</p>
  716. </div>
  717. <p>It is possible to modify how enum members are pickled/unpickled by defining
  718. <code class="xref py py-meth docutils literal notranslate"><span class="pre">__reduce_ex__()</span></code> in the enumeration class. The default method is by-value,
  719. but enums with complicated values may want to use by-name:</p>
  720. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="kn">import</span> <span class="nn">enum</span>
  721. <span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">MyEnum</span><span class="p">(</span><span class="n">enum</span><span class="o">.</span><span class="n">Enum</span><span class="p">):</span>
  722. <span class="gp">... </span> <span class="n">__reduce_ex__</span> <span class="o">=</span> <span class="n">enum</span><span class="o">.</span><span class="n">pickle_by_enum_name</span>
  723. </pre></div>
  724. </div>
  725. <div class="admonition note">
  726. <p class="admonition-title">Note</p>
  727. <p>Using by-name for flags is not recommended, as unnamed aliases will
  728. not unpickle.</p>
  729. </div>
  730. </section>
  731. <section id="functional-api">
  732. <h2>Functional API<a class="headerlink" href="#functional-api" title="Link to this heading">¶</a></h2>
  733. <p>The <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> class is callable, providing the following functional API:</p>
  734. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">Animal</span> <span class="o">=</span> <span class="n">Enum</span><span class="p">(</span><span class="s1">&#39;Animal&#39;</span><span class="p">,</span> <span class="s1">&#39;ANT BEE CAT DOG&#39;</span><span class="p">)</span>
  735. <span class="gp">&gt;&gt;&gt; </span><span class="n">Animal</span>
  736. <span class="go">&lt;enum &#39;Animal&#39;&gt;</span>
  737. <span class="gp">&gt;&gt;&gt; </span><span class="n">Animal</span><span class="o">.</span><span class="n">ANT</span>
  738. <span class="go">&lt;Animal.ANT: 1&gt;</span>
  739. <span class="gp">&gt;&gt;&gt; </span><span class="nb">list</span><span class="p">(</span><span class="n">Animal</span><span class="p">)</span>
  740. <span class="go">[&lt;Animal.ANT: 1&gt;, &lt;Animal.BEE: 2&gt;, &lt;Animal.CAT: 3&gt;, &lt;Animal.DOG: 4&gt;]</span>
  741. </pre></div>
  742. </div>
  743. <p>The semantics of this API resemble <a class="reference internal" href="../library/collections.html#collections.namedtuple" title="collections.namedtuple"><code class="xref py py-class docutils literal notranslate"><span class="pre">namedtuple</span></code></a>. The first
  744. argument of the call to <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> is the name of the enumeration.</p>
  745. <p>The second argument is the <em>source</em> of enumeration member names. It can be a
  746. whitespace-separated string of names, a sequence of names, a sequence of
  747. 2-tuples with key/value pairs, or a mapping (e.g. dictionary) of names to
  748. values. The last two options enable assigning arbitrary values to
  749. enumerations; the others auto-assign increasing integers starting with 1 (use
  750. the <code class="docutils literal notranslate"><span class="pre">start</span></code> parameter to specify a different starting value). A
  751. new class derived from <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> is returned. In other words, the above
  752. assignment to <code class="xref py py-class docutils literal notranslate"><span class="pre">Animal</span></code> is equivalent to:</p>
  753. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Animal</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  754. <span class="gp">... </span> <span class="n">ANT</span> <span class="o">=</span> <span class="mi">1</span>
  755. <span class="gp">... </span> <span class="n">BEE</span> <span class="o">=</span> <span class="mi">2</span>
  756. <span class="gp">... </span> <span class="n">CAT</span> <span class="o">=</span> <span class="mi">3</span>
  757. <span class="gp">... </span> <span class="n">DOG</span> <span class="o">=</span> <span class="mi">4</span>
  758. <span class="gp">...</span>
  759. </pre></div>
  760. </div>
  761. <p>The reason for defaulting to <code class="docutils literal notranslate"><span class="pre">1</span></code> as the starting number and not <code class="docutils literal notranslate"><span class="pre">0</span></code> is
  762. that <code class="docutils literal notranslate"><span class="pre">0</span></code> is <code class="docutils literal notranslate"><span class="pre">False</span></code> in a boolean sense, but by default enum members all
  763. evaluate to <code class="docutils literal notranslate"><span class="pre">True</span></code>.</p>
  764. <p>Pickling enums created with the functional API can be tricky as frame stack
  765. implementation details are used to try and figure out which module the
  766. enumeration is being created in (e.g. it will fail if you use a utility
  767. function in a separate module, and also may not work on IronPython or Jython).
  768. The solution is to specify the module name explicitly as follows:</p>
  769. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">Animal</span> <span class="o">=</span> <span class="n">Enum</span><span class="p">(</span><span class="s1">&#39;Animal&#39;</span><span class="p">,</span> <span class="s1">&#39;ANT BEE CAT DOG&#39;</span><span class="p">,</span> <span class="n">module</span><span class="o">=</span><span class="vm">__name__</span><span class="p">)</span>
  770. </pre></div>
  771. </div>
  772. <div class="admonition warning">
  773. <p class="admonition-title">Warning</p>
  774. <p>If <code class="docutils literal notranslate"><span class="pre">module</span></code> is not supplied, and Enum cannot determine what it is,
  775. the new Enum members will not be unpicklable; to keep errors closer to
  776. the source, pickling will be disabled.</p>
  777. </div>
  778. <p>The new pickle protocol 4 also, in some circumstances, relies on
  779. <a class="reference internal" href="../library/stdtypes.html#definition.__qualname__" title="definition.__qualname__"><code class="xref py py-attr docutils literal notranslate"><span class="pre">__qualname__</span></code></a> being set to the location where pickle will be able
  780. to find the class. For example, if the class was made available in class
  781. SomeData in the global scope:</p>
  782. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">Animal</span> <span class="o">=</span> <span class="n">Enum</span><span class="p">(</span><span class="s1">&#39;Animal&#39;</span><span class="p">,</span> <span class="s1">&#39;ANT BEE CAT DOG&#39;</span><span class="p">,</span> <span class="n">qualname</span><span class="o">=</span><span class="s1">&#39;SomeData.Animal&#39;</span><span class="p">)</span>
  783. </pre></div>
  784. </div>
  785. <p>The complete signature is:</p>
  786. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="n">Enum</span><span class="p">(</span>
  787. <span class="n">value</span><span class="o">=</span><span class="s1">&#39;NewEnumName&#39;</span><span class="p">,</span>
  788. <span class="n">names</span><span class="o">=&lt;...&gt;</span><span class="p">,</span>
  789. <span class="o">*</span><span class="p">,</span>
  790. <span class="n">module</span><span class="o">=</span><span class="s1">&#39;...&#39;</span><span class="p">,</span>
  791. <span class="n">qualname</span><span class="o">=</span><span class="s1">&#39;...&#39;</span><span class="p">,</span>
  792. <span class="nb">type</span><span class="o">=&lt;</span><span class="n">mixed</span><span class="o">-</span><span class="ow">in</span> <span class="n">class</span><span class="o">&gt;</span><span class="p">,</span>
  793. <span class="n">start</span><span class="o">=</span><span class="mi">1</span><span class="p">,</span>
  794. <span class="p">)</span>
  795. </pre></div>
  796. </div>
  797. <ul>
  798. <li><p><em>value</em>: What the new enum class will record as its name.</p></li>
  799. <li><p><em>names</em>: The enum members. This can be a whitespace- or comma-separated string
  800. (values will start at 1 unless otherwise specified):</p>
  801. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="s1">&#39;RED GREEN BLUE&#39;</span> <span class="o">|</span> <span class="s1">&#39;RED,GREEN,BLUE&#39;</span> <span class="o">|</span> <span class="s1">&#39;RED, GREEN, BLUE&#39;</span>
  802. </pre></div>
  803. </div>
  804. <p>or an iterator of names:</p>
  805. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="p">[</span><span class="s1">&#39;RED&#39;</span><span class="p">,</span> <span class="s1">&#39;GREEN&#39;</span><span class="p">,</span> <span class="s1">&#39;BLUE&#39;</span><span class="p">]</span>
  806. </pre></div>
  807. </div>
  808. <p>or an iterator of (name, value) pairs:</p>
  809. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="p">[(</span><span class="s1">&#39;CYAN&#39;</span><span class="p">,</span> <span class="mi">4</span><span class="p">),</span> <span class="p">(</span><span class="s1">&#39;MAGENTA&#39;</span><span class="p">,</span> <span class="mi">5</span><span class="p">),</span> <span class="p">(</span><span class="s1">&#39;YELLOW&#39;</span><span class="p">,</span> <span class="mi">6</span><span class="p">)]</span>
  810. </pre></div>
  811. </div>
  812. <p>or a mapping:</p>
  813. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="p">{</span><span class="s1">&#39;CHARTREUSE&#39;</span><span class="p">:</span> <span class="mi">7</span><span class="p">,</span> <span class="s1">&#39;SEA_GREEN&#39;</span><span class="p">:</span> <span class="mi">11</span><span class="p">,</span> <span class="s1">&#39;ROSEMARY&#39;</span><span class="p">:</span> <span class="mi">42</span><span class="p">}</span>
  814. </pre></div>
  815. </div>
  816. </li>
  817. <li><p><em>module</em>: name of module where new enum class can be found.</p></li>
  818. <li><p><em>qualname</em>: where in module new enum class can be found.</p></li>
  819. <li><p><em>type</em>: type to mix in to new enum class.</p></li>
  820. <li><p><em>start</em>: number to start counting at if only names are passed in.</p></li>
  821. </ul>
  822. <div class="versionchanged">
  823. <p><span class="versionmodified changed">Changed in version 3.5: </span>The <em>start</em> parameter was added.</p>
  824. </div>
  825. </section>
  826. <section id="derived-enumerations">
  827. <h2>Derived Enumerations<a class="headerlink" href="#derived-enumerations" title="Link to this heading">¶</a></h2>
  828. <section id="intenum">
  829. <h3>IntEnum<a class="headerlink" href="#intenum" title="Link to this heading">¶</a></h3>
  830. <p>The first variation of <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> that is provided is also a subclass of
  831. <a class="reference internal" href="../library/functions.html#int" title="int"><code class="xref py py-class docutils literal notranslate"><span class="pre">int</span></code></a>. Members of an <a class="reference internal" href="../library/enum.html#enum.IntEnum" title="enum.IntEnum"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntEnum</span></code></a> can be compared to integers;
  832. by extension, integer enumerations of different types can also be compared
  833. to each other:</p>
  834. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="kn">from</span> <span class="nn">enum</span> <span class="kn">import</span> <span class="n">IntEnum</span>
  835. <span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Shape</span><span class="p">(</span><span class="n">IntEnum</span><span class="p">):</span>
  836. <span class="gp">... </span> <span class="n">CIRCLE</span> <span class="o">=</span> <span class="mi">1</span>
  837. <span class="gp">... </span> <span class="n">SQUARE</span> <span class="o">=</span> <span class="mi">2</span>
  838. <span class="gp">...</span>
  839. <span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Request</span><span class="p">(</span><span class="n">IntEnum</span><span class="p">):</span>
  840. <span class="gp">... </span> <span class="n">POST</span> <span class="o">=</span> <span class="mi">1</span>
  841. <span class="gp">... </span> <span class="n">GET</span> <span class="o">=</span> <span class="mi">2</span>
  842. <span class="gp">...</span>
  843. <span class="gp">&gt;&gt;&gt; </span><span class="n">Shape</span> <span class="o">==</span> <span class="mi">1</span>
  844. <span class="go">False</span>
  845. <span class="gp">&gt;&gt;&gt; </span><span class="n">Shape</span><span class="o">.</span><span class="n">CIRCLE</span> <span class="o">==</span> <span class="mi">1</span>
  846. <span class="go">True</span>
  847. <span class="gp">&gt;&gt;&gt; </span><span class="n">Shape</span><span class="o">.</span><span class="n">CIRCLE</span> <span class="o">==</span> <span class="n">Request</span><span class="o">.</span><span class="n">POST</span>
  848. <span class="go">True</span>
  849. </pre></div>
  850. </div>
  851. <p>However, they still can’t be compared to standard <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> enumerations:</p>
  852. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Shape</span><span class="p">(</span><span class="n">IntEnum</span><span class="p">):</span>
  853. <span class="gp">... </span> <span class="n">CIRCLE</span> <span class="o">=</span> <span class="mi">1</span>
  854. <span class="gp">... </span> <span class="n">SQUARE</span> <span class="o">=</span> <span class="mi">2</span>
  855. <span class="gp">...</span>
  856. <span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Color</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  857. <span class="gp">... </span> <span class="n">RED</span> <span class="o">=</span> <span class="mi">1</span>
  858. <span class="gp">... </span> <span class="n">GREEN</span> <span class="o">=</span> <span class="mi">2</span>
  859. <span class="gp">...</span>
  860. <span class="gp">&gt;&gt;&gt; </span><span class="n">Shape</span><span class="o">.</span><span class="n">CIRCLE</span> <span class="o">==</span> <span class="n">Color</span><span class="o">.</span><span class="n">RED</span>
  861. <span class="go">False</span>
  862. </pre></div>
  863. </div>
  864. <p><a class="reference internal" href="../library/enum.html#enum.IntEnum" title="enum.IntEnum"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntEnum</span></code></a> values behave like integers in other ways you’d expect:</p>
  865. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="nb">int</span><span class="p">(</span><span class="n">Shape</span><span class="o">.</span><span class="n">CIRCLE</span><span class="p">)</span>
  866. <span class="go">1</span>
  867. <span class="gp">&gt;&gt;&gt; </span><span class="p">[</span><span class="s1">&#39;a&#39;</span><span class="p">,</span> <span class="s1">&#39;b&#39;</span><span class="p">,</span> <span class="s1">&#39;c&#39;</span><span class="p">][</span><span class="n">Shape</span><span class="o">.</span><span class="n">CIRCLE</span><span class="p">]</span>
  868. <span class="go">&#39;b&#39;</span>
  869. <span class="gp">&gt;&gt;&gt; </span><span class="p">[</span><span class="n">i</span> <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="n">Shape</span><span class="o">.</span><span class="n">SQUARE</span><span class="p">)]</span>
  870. <span class="go">[0, 1]</span>
  871. </pre></div>
  872. </div>
  873. </section>
  874. <section id="strenum">
  875. <h3>StrEnum<a class="headerlink" href="#strenum" title="Link to this heading">¶</a></h3>
  876. <p>The second variation of <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> that is provided is also a subclass of
  877. <a class="reference internal" href="../library/stdtypes.html#str" title="str"><code class="xref py py-class docutils literal notranslate"><span class="pre">str</span></code></a>. Members of a <a class="reference internal" href="../library/enum.html#enum.StrEnum" title="enum.StrEnum"><code class="xref py py-class docutils literal notranslate"><span class="pre">StrEnum</span></code></a> can be compared to strings;
  878. by extension, string enumerations of different types can also be compared
  879. to each other.</p>
  880. <div class="versionadded">
  881. <p><span class="versionmodified added">New in version 3.11.</span></p>
  882. </div>
  883. </section>
  884. <section id="intflag">
  885. <h3>IntFlag<a class="headerlink" href="#intflag" title="Link to this heading">¶</a></h3>
  886. <p>The next variation of <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> provided, <a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a>, is also based
  887. on <a class="reference internal" href="../library/functions.html#int" title="int"><code class="xref py py-class docutils literal notranslate"><span class="pre">int</span></code></a>. The difference being <a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a> members can be combined
  888. using the bitwise operators (&amp;, |, ^, ~) and the result is still an
  889. <a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a> member, if possible. Like <a class="reference internal" href="../library/enum.html#enum.IntEnum" title="enum.IntEnum"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntEnum</span></code></a>, <a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a>
  890. members are also integers and can be used wherever an <a class="reference internal" href="../library/functions.html#int" title="int"><code class="xref py py-class docutils literal notranslate"><span class="pre">int</span></code></a> is used.</p>
  891. <div class="admonition note">
  892. <p class="admonition-title">Note</p>
  893. <p>Any operation on an <a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a> member besides the bit-wise operations will
  894. lose the <a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a> membership.</p>
  895. <p>Bit-wise operations that result in invalid <a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a> values will lose the
  896. <a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a> membership. See <a class="reference internal" href="../library/enum.html#enum.FlagBoundary" title="enum.FlagBoundary"><code class="xref py py-class docutils literal notranslate"><span class="pre">FlagBoundary</span></code></a> for
  897. details.</p>
  898. </div>
  899. <div class="versionadded">
  900. <p><span class="versionmodified added">New in version 3.6.</span></p>
  901. </div>
  902. <div class="versionchanged">
  903. <p><span class="versionmodified changed">Changed in version 3.11.</span></p>
  904. </div>
  905. <p>Sample <a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a> class:</p>
  906. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="kn">from</span> <span class="nn">enum</span> <span class="kn">import</span> <span class="n">IntFlag</span>
  907. <span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Perm</span><span class="p">(</span><span class="n">IntFlag</span><span class="p">):</span>
  908. <span class="gp">... </span> <span class="n">R</span> <span class="o">=</span> <span class="mi">4</span>
  909. <span class="gp">... </span> <span class="n">W</span> <span class="o">=</span> <span class="mi">2</span>
  910. <span class="gp">... </span> <span class="n">X</span> <span class="o">=</span> <span class="mi">1</span>
  911. <span class="gp">...</span>
  912. <span class="gp">&gt;&gt;&gt; </span><span class="n">Perm</span><span class="o">.</span><span class="n">R</span> <span class="o">|</span> <span class="n">Perm</span><span class="o">.</span><span class="n">W</span>
  913. <span class="go">&lt;Perm.R|W: 6&gt;</span>
  914. <span class="gp">&gt;&gt;&gt; </span><span class="n">Perm</span><span class="o">.</span><span class="n">R</span> <span class="o">+</span> <span class="n">Perm</span><span class="o">.</span><span class="n">W</span>
  915. <span class="go">6</span>
  916. <span class="gp">&gt;&gt;&gt; </span><span class="n">RW</span> <span class="o">=</span> <span class="n">Perm</span><span class="o">.</span><span class="n">R</span> <span class="o">|</span> <span class="n">Perm</span><span class="o">.</span><span class="n">W</span>
  917. <span class="gp">&gt;&gt;&gt; </span><span class="n">Perm</span><span class="o">.</span><span class="n">R</span> <span class="ow">in</span> <span class="n">RW</span>
  918. <span class="go">True</span>
  919. </pre></div>
  920. </div>
  921. <p>It is also possible to name the combinations:</p>
  922. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Perm</span><span class="p">(</span><span class="n">IntFlag</span><span class="p">):</span>
  923. <span class="gp">... </span> <span class="n">R</span> <span class="o">=</span> <span class="mi">4</span>
  924. <span class="gp">... </span> <span class="n">W</span> <span class="o">=</span> <span class="mi">2</span>
  925. <span class="gp">... </span> <span class="n">X</span> <span class="o">=</span> <span class="mi">1</span>
  926. <span class="gp">... </span> <span class="n">RWX</span> <span class="o">=</span> <span class="mi">7</span>
  927. <span class="gp">...</span>
  928. <span class="gp">&gt;&gt;&gt; </span><span class="n">Perm</span><span class="o">.</span><span class="n">RWX</span>
  929. <span class="go">&lt;Perm.RWX: 7&gt;</span>
  930. <span class="gp">&gt;&gt;&gt; </span><span class="o">~</span><span class="n">Perm</span><span class="o">.</span><span class="n">RWX</span>
  931. <span class="go">&lt;Perm: 0&gt;</span>
  932. <span class="gp">&gt;&gt;&gt; </span><span class="n">Perm</span><span class="p">(</span><span class="mi">7</span><span class="p">)</span>
  933. <span class="go">&lt;Perm.RWX: 7&gt;</span>
  934. </pre></div>
  935. </div>
  936. <div class="admonition note">
  937. <p class="admonition-title">Note</p>
  938. <p>Named combinations are considered aliases. Aliases do not show up during
  939. iteration, but can be returned from by-value lookups.</p>
  940. </div>
  941. <div class="versionchanged">
  942. <p><span class="versionmodified changed">Changed in version 3.11.</span></p>
  943. </div>
  944. <p>Another important difference between <a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a> and <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> is that
  945. if no flags are set (the value is 0), its boolean evaluation is <a class="reference internal" href="../library/constants.html#False" title="False"><code class="xref py py-data docutils literal notranslate"><span class="pre">False</span></code></a>:</p>
  946. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">Perm</span><span class="o">.</span><span class="n">R</span> <span class="o">&amp;</span> <span class="n">Perm</span><span class="o">.</span><span class="n">X</span>
  947. <span class="go">&lt;Perm: 0&gt;</span>
  948. <span class="gp">&gt;&gt;&gt; </span><span class="nb">bool</span><span class="p">(</span><span class="n">Perm</span><span class="o">.</span><span class="n">R</span> <span class="o">&amp;</span> <span class="n">Perm</span><span class="o">.</span><span class="n">X</span><span class="p">)</span>
  949. <span class="go">False</span>
  950. </pre></div>
  951. </div>
  952. <p>Because <a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a> members are also subclasses of <a class="reference internal" href="../library/functions.html#int" title="int"><code class="xref py py-class docutils literal notranslate"><span class="pre">int</span></code></a> they can
  953. be combined with them (but may lose <a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a> membership:</p>
  954. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">Perm</span><span class="o">.</span><span class="n">X</span> <span class="o">|</span> <span class="mi">4</span>
  955. <span class="go">&lt;Perm.R|X: 5&gt;</span>
  956. <span class="gp">&gt;&gt;&gt; </span><span class="n">Perm</span><span class="o">.</span><span class="n">X</span> <span class="o">+</span> <span class="mi">8</span>
  957. <span class="go">9</span>
  958. </pre></div>
  959. </div>
  960. <div class="admonition note">
  961. <p class="admonition-title">Note</p>
  962. <p>The negation operator, <code class="docutils literal notranslate"><span class="pre">~</span></code>, always returns an <a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a> member with a
  963. positive value:</p>
  964. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="p">(</span><span class="o">~</span><span class="n">Perm</span><span class="o">.</span><span class="n">X</span><span class="p">)</span><span class="o">.</span><span class="n">value</span> <span class="o">==</span> <span class="p">(</span><span class="n">Perm</span><span class="o">.</span><span class="n">R</span><span class="o">|</span><span class="n">Perm</span><span class="o">.</span><span class="n">W</span><span class="p">)</span><span class="o">.</span><span class="n">value</span> <span class="o">==</span> <span class="mi">6</span>
  965. <span class="go">True</span>
  966. </pre></div>
  967. </div>
  968. </div>
  969. <p><a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a> members can also be iterated over:</p>
  970. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="nb">list</span><span class="p">(</span><span class="n">RW</span><span class="p">)</span>
  971. <span class="go">[&lt;Perm.R: 4&gt;, &lt;Perm.W: 2&gt;]</span>
  972. </pre></div>
  973. </div>
  974. <div class="versionadded">
  975. <p><span class="versionmodified added">New in version 3.11.</span></p>
  976. </div>
  977. </section>
  978. <section id="flag">
  979. <h3>Flag<a class="headerlink" href="#flag" title="Link to this heading">¶</a></h3>
  980. <p>The last variation is <a class="reference internal" href="../library/enum.html#enum.Flag" title="enum.Flag"><code class="xref py py-class docutils literal notranslate"><span class="pre">Flag</span></code></a>. Like <a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a>, <a class="reference internal" href="../library/enum.html#enum.Flag" title="enum.Flag"><code class="xref py py-class docutils literal notranslate"><span class="pre">Flag</span></code></a>
  981. members can be combined using the bitwise operators (&amp;, |, ^, ~). Unlike
  982. <a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a>, they cannot be combined with, nor compared against, any
  983. other <a class="reference internal" href="../library/enum.html#enum.Flag" title="enum.Flag"><code class="xref py py-class docutils literal notranslate"><span class="pre">Flag</span></code></a> enumeration, nor <a class="reference internal" href="../library/functions.html#int" title="int"><code class="xref py py-class docutils literal notranslate"><span class="pre">int</span></code></a>. While it is possible to
  984. specify the values directly it is recommended to use <a class="reference internal" href="../library/enum.html#enum.auto" title="enum.auto"><code class="xref py py-class docutils literal notranslate"><span class="pre">auto</span></code></a> as the
  985. value and let <a class="reference internal" href="../library/enum.html#enum.Flag" title="enum.Flag"><code class="xref py py-class docutils literal notranslate"><span class="pre">Flag</span></code></a> select an appropriate value.</p>
  986. <div class="versionadded">
  987. <p><span class="versionmodified added">New in version 3.6.</span></p>
  988. </div>
  989. <p>Like <a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a>, if a combination of <a class="reference internal" href="../library/enum.html#enum.Flag" title="enum.Flag"><code class="xref py py-class docutils literal notranslate"><span class="pre">Flag</span></code></a> members results in no
  990. flags being set, the boolean evaluation is <a class="reference internal" href="../library/constants.html#False" title="False"><code class="xref py py-data docutils literal notranslate"><span class="pre">False</span></code></a>:</p>
  991. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="kn">from</span> <span class="nn">enum</span> <span class="kn">import</span> <span class="n">Flag</span><span class="p">,</span> <span class="n">auto</span>
  992. <span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Color</span><span class="p">(</span><span class="n">Flag</span><span class="p">):</span>
  993. <span class="gp">... </span> <span class="n">RED</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  994. <span class="gp">... </span> <span class="n">BLUE</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  995. <span class="gp">... </span> <span class="n">GREEN</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  996. <span class="gp">...</span>
  997. <span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">RED</span> <span class="o">&amp;</span> <span class="n">Color</span><span class="o">.</span><span class="n">GREEN</span>
  998. <span class="go">&lt;Color: 0&gt;</span>
  999. <span class="gp">&gt;&gt;&gt; </span><span class="nb">bool</span><span class="p">(</span><span class="n">Color</span><span class="o">.</span><span class="n">RED</span> <span class="o">&amp;</span> <span class="n">Color</span><span class="o">.</span><span class="n">GREEN</span><span class="p">)</span>
  1000. <span class="go">False</span>
  1001. </pre></div>
  1002. </div>
  1003. <p>Individual flags should have values that are powers of two (1, 2, 4, 8, …),
  1004. while combinations of flags will not:</p>
  1005. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Color</span><span class="p">(</span><span class="n">Flag</span><span class="p">):</span>
  1006. <span class="gp">... </span> <span class="n">RED</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  1007. <span class="gp">... </span> <span class="n">BLUE</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  1008. <span class="gp">... </span> <span class="n">GREEN</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  1009. <span class="gp">... </span> <span class="n">WHITE</span> <span class="o">=</span> <span class="n">RED</span> <span class="o">|</span> <span class="n">BLUE</span> <span class="o">|</span> <span class="n">GREEN</span>
  1010. <span class="gp">...</span>
  1011. <span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">WHITE</span>
  1012. <span class="go">&lt;Color.WHITE: 7&gt;</span>
  1013. </pre></div>
  1014. </div>
  1015. <p>Giving a name to the “no flags set” condition does not change its boolean
  1016. value:</p>
  1017. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Color</span><span class="p">(</span><span class="n">Flag</span><span class="p">):</span>
  1018. <span class="gp">... </span> <span class="n">BLACK</span> <span class="o">=</span> <span class="mi">0</span>
  1019. <span class="gp">... </span> <span class="n">RED</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  1020. <span class="gp">... </span> <span class="n">BLUE</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  1021. <span class="gp">... </span> <span class="n">GREEN</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  1022. <span class="gp">...</span>
  1023. <span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">BLACK</span>
  1024. <span class="go">&lt;Color.BLACK: 0&gt;</span>
  1025. <span class="gp">&gt;&gt;&gt; </span><span class="nb">bool</span><span class="p">(</span><span class="n">Color</span><span class="o">.</span><span class="n">BLACK</span><span class="p">)</span>
  1026. <span class="go">False</span>
  1027. </pre></div>
  1028. </div>
  1029. <p><a class="reference internal" href="../library/enum.html#enum.Flag" title="enum.Flag"><code class="xref py py-class docutils literal notranslate"><span class="pre">Flag</span></code></a> members can also be iterated over:</p>
  1030. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">purple</span> <span class="o">=</span> <span class="n">Color</span><span class="o">.</span><span class="n">RED</span> <span class="o">|</span> <span class="n">Color</span><span class="o">.</span><span class="n">BLUE</span>
  1031. <span class="gp">&gt;&gt;&gt; </span><span class="nb">list</span><span class="p">(</span><span class="n">purple</span><span class="p">)</span>
  1032. <span class="go">[&lt;Color.RED: 1&gt;, &lt;Color.BLUE: 2&gt;]</span>
  1033. </pre></div>
  1034. </div>
  1035. <div class="versionadded">
  1036. <p><span class="versionmodified added">New in version 3.11.</span></p>
  1037. </div>
  1038. <div class="admonition note">
  1039. <p class="admonition-title">Note</p>
  1040. <p>For the majority of new code, <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> and <a class="reference internal" href="../library/enum.html#enum.Flag" title="enum.Flag"><code class="xref py py-class docutils literal notranslate"><span class="pre">Flag</span></code></a> are strongly
  1041. recommended, since <a class="reference internal" href="../library/enum.html#enum.IntEnum" title="enum.IntEnum"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntEnum</span></code></a> and <a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a> break some
  1042. semantic promises of an enumeration (by being comparable to integers, and
  1043. thus by transitivity to other unrelated enumerations). <a class="reference internal" href="../library/enum.html#enum.IntEnum" title="enum.IntEnum"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntEnum</span></code></a>
  1044. and <a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a> should be used only in cases where <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> and
  1045. <a class="reference internal" href="../library/enum.html#enum.Flag" title="enum.Flag"><code class="xref py py-class docutils literal notranslate"><span class="pre">Flag</span></code></a> will not do; for example, when integer constants are replaced
  1046. with enumerations, or for interoperability with other systems.</p>
  1047. </div>
  1048. </section>
  1049. <section id="others">
  1050. <h3>Others<a class="headerlink" href="#others" title="Link to this heading">¶</a></h3>
  1051. <p>While <a class="reference internal" href="../library/enum.html#enum.IntEnum" title="enum.IntEnum"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntEnum</span></code></a> is part of the <a class="reference internal" href="../library/enum.html#module-enum" title="enum: Implementation of an enumeration class."><code class="xref py py-mod docutils literal notranslate"><span class="pre">enum</span></code></a> module, it would be very
  1052. simple to implement independently:</p>
  1053. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="k">class</span> <span class="nc">IntEnum</span><span class="p">(</span><span class="nb">int</span><span class="p">,</span> <span class="n">Enum</span><span class="p">):</span>
  1054. <span class="k">pass</span>
  1055. </pre></div>
  1056. </div>
  1057. <p>This demonstrates how similar derived enumerations can be defined; for example
  1058. a <code class="xref py py-class docutils literal notranslate"><span class="pre">FloatEnum</span></code> that mixes in <a class="reference internal" href="../library/functions.html#float" title="float"><code class="xref py py-class docutils literal notranslate"><span class="pre">float</span></code></a> instead of <a class="reference internal" href="../library/functions.html#int" title="int"><code class="xref py py-class docutils literal notranslate"><span class="pre">int</span></code></a>.</p>
  1059. <p>Some rules:</p>
  1060. <ol class="arabic simple">
  1061. <li><p>When subclassing <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a>, mix-in types must appear before
  1062. <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> itself in the sequence of bases, as in the <a class="reference internal" href="../library/enum.html#enum.IntEnum" title="enum.IntEnum"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntEnum</span></code></a>
  1063. example above.</p></li>
  1064. <li><p>Mix-in types must be subclassable. For example, <a class="reference internal" href="../library/functions.html#bool" title="bool"><code class="xref py py-class docutils literal notranslate"><span class="pre">bool</span></code></a> and
  1065. <a class="reference internal" href="../library/stdtypes.html#range" title="range"><code class="xref py py-class docutils literal notranslate"><span class="pre">range</span></code></a> are not subclassable and will throw an error during Enum
  1066. creation if used as the mix-in type.</p></li>
  1067. <li><p>While <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> can have members of any type, once you mix in an
  1068. additional type, all the members must have values of that type, e.g.
  1069. <a class="reference internal" href="../library/functions.html#int" title="int"><code class="xref py py-class docutils literal notranslate"><span class="pre">int</span></code></a> above. This restriction does not apply to mix-ins which only
  1070. add methods and don’t specify another type.</p></li>
  1071. <li><p>When another data type is mixed in, the <code class="xref py py-attr docutils literal notranslate"><span class="pre">value</span></code> attribute is <em>not the
  1072. same</em> as the enum member itself, although it is equivalent and will compare
  1073. equal.</p></li>
  1074. <li><p>A <code class="docutils literal notranslate"><span class="pre">data</span> <span class="pre">type</span></code> is a mixin that defines <code class="xref py py-meth docutils literal notranslate"><span class="pre">__new__()</span></code>, or a
  1075. <a class="reference internal" href="../library/dataclasses.html#dataclasses.dataclass" title="dataclasses.dataclass"><code class="xref py py-class docutils literal notranslate"><span class="pre">dataclass</span></code></a></p></li>
  1076. <li><p>%-style formatting: <code class="docutils literal notranslate"><span class="pre">%s</span></code> and <code class="docutils literal notranslate"><span class="pre">%r</span></code> call the <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> class’s
  1077. <code class="xref py py-meth docutils literal notranslate"><span class="pre">__str__()</span></code> and <code class="xref py py-meth docutils literal notranslate"><span class="pre">__repr__()</span></code> respectively; other codes (such as
  1078. <code class="docutils literal notranslate"><span class="pre">%i</span></code> or <code class="docutils literal notranslate"><span class="pre">%h</span></code> for IntEnum) treat the enum member as its mixed-in type.</p></li>
  1079. <li><p><a class="reference internal" href="../reference/lexical_analysis.html#f-strings"><span class="std std-ref">Formatted string literals</span></a>, <a class="reference internal" href="../library/stdtypes.html#str.format" title="str.format"><code class="xref py py-meth docutils literal notranslate"><span class="pre">str.format()</span></code></a>,
  1080. and <a class="reference internal" href="../library/functions.html#format" title="format"><code class="xref py py-func docutils literal notranslate"><span class="pre">format()</span></code></a> will use the enum’s <code class="xref py py-meth docutils literal notranslate"><span class="pre">__str__()</span></code> method.</p></li>
  1081. </ol>
  1082. <div class="admonition note">
  1083. <p class="admonition-title">Note</p>
  1084. <p>Because <a class="reference internal" href="../library/enum.html#enum.IntEnum" title="enum.IntEnum"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntEnum</span></code></a>, <a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a>, and <a class="reference internal" href="../library/enum.html#enum.StrEnum" title="enum.StrEnum"><code class="xref py py-class docutils literal notranslate"><span class="pre">StrEnum</span></code></a> are
  1085. designed to be drop-in replacements for existing constants, their
  1086. <code class="xref py py-meth docutils literal notranslate"><span class="pre">__str__()</span></code> method has been reset to their data types’
  1087. <code class="xref py py-meth docutils literal notranslate"><span class="pre">__str__()</span></code> method.</p>
  1088. </div>
  1089. </section>
  1090. </section>
  1091. <section id="when-to-use-new-vs-init">
  1092. <span id="new-vs-init"></span><h2>When to use <code class="xref py py-meth docutils literal notranslate"><span class="pre">__new__()</span></code> vs. <code class="xref py py-meth docutils literal notranslate"><span class="pre">__init__()</span></code><a class="headerlink" href="#when-to-use-new-vs-init" title="Link to this heading">¶</a></h2>
  1093. <p><code class="xref py py-meth docutils literal notranslate"><span class="pre">__new__()</span></code> must be used whenever you want to customize the actual value of
  1094. the <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> member. Any other modifications may go in either
  1095. <code class="xref py py-meth docutils literal notranslate"><span class="pre">__new__()</span></code> or <code class="xref py py-meth docutils literal notranslate"><span class="pre">__init__()</span></code>, with <code class="xref py py-meth docutils literal notranslate"><span class="pre">__init__()</span></code> being preferred.</p>
  1096. <p>For example, if you want to pass several items to the constructor, but only
  1097. want one of them to be the value:</p>
  1098. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Coordinate</span><span class="p">(</span><span class="nb">bytes</span><span class="p">,</span> <span class="n">Enum</span><span class="p">):</span>
  1099. <span class="gp">... </span><span class="w"> </span><span class="sd">&quot;&quot;&quot;</span>
  1100. <span class="gp">... </span><span class="sd"> Coordinate with binary codes that can be indexed by the int code.</span>
  1101. <span class="gp">... </span><span class="sd"> &quot;&quot;&quot;</span>
  1102. <span class="gp">... </span> <span class="k">def</span> <span class="fm">__new__</span><span class="p">(</span><span class="bp">cls</span><span class="p">,</span> <span class="n">value</span><span class="p">,</span> <span class="n">label</span><span class="p">,</span> <span class="n">unit</span><span class="p">):</span>
  1103. <span class="gp">... </span> <span class="n">obj</span> <span class="o">=</span> <span class="nb">bytes</span><span class="o">.</span><span class="fm">__new__</span><span class="p">(</span><span class="bp">cls</span><span class="p">,</span> <span class="p">[</span><span class="n">value</span><span class="p">])</span>
  1104. <span class="gp">... </span> <span class="n">obj</span><span class="o">.</span><span class="n">_value_</span> <span class="o">=</span> <span class="n">value</span>
  1105. <span class="gp">... </span> <span class="n">obj</span><span class="o">.</span><span class="n">label</span> <span class="o">=</span> <span class="n">label</span>
  1106. <span class="gp">... </span> <span class="n">obj</span><span class="o">.</span><span class="n">unit</span> <span class="o">=</span> <span class="n">unit</span>
  1107. <span class="gp">... </span> <span class="k">return</span> <span class="n">obj</span>
  1108. <span class="gp">... </span> <span class="n">PX</span> <span class="o">=</span> <span class="p">(</span><span class="mi">0</span><span class="p">,</span> <span class="s1">&#39;P.X&#39;</span><span class="p">,</span> <span class="s1">&#39;km&#39;</span><span class="p">)</span>
  1109. <span class="gp">... </span> <span class="n">PY</span> <span class="o">=</span> <span class="p">(</span><span class="mi">1</span><span class="p">,</span> <span class="s1">&#39;P.Y&#39;</span><span class="p">,</span> <span class="s1">&#39;km&#39;</span><span class="p">)</span>
  1110. <span class="gp">... </span> <span class="n">VX</span> <span class="o">=</span> <span class="p">(</span><span class="mi">2</span><span class="p">,</span> <span class="s1">&#39;V.X&#39;</span><span class="p">,</span> <span class="s1">&#39;km/s&#39;</span><span class="p">)</span>
  1111. <span class="gp">... </span> <span class="n">VY</span> <span class="o">=</span> <span class="p">(</span><span class="mi">3</span><span class="p">,</span> <span class="s1">&#39;V.Y&#39;</span><span class="p">,</span> <span class="s1">&#39;km/s&#39;</span><span class="p">)</span>
  1112. <span class="gp">...</span>
  1113. <span class="gp">&gt;&gt;&gt; </span><span class="nb">print</span><span class="p">(</span><span class="n">Coordinate</span><span class="p">[</span><span class="s1">&#39;PY&#39;</span><span class="p">])</span>
  1114. <span class="go">Coordinate.PY</span>
  1115. <span class="gp">&gt;&gt;&gt; </span><span class="nb">print</span><span class="p">(</span><span class="n">Coordinate</span><span class="p">(</span><span class="mi">3</span><span class="p">))</span>
  1116. <span class="go">Coordinate.VY</span>
  1117. </pre></div>
  1118. </div>
  1119. <div class="admonition warning">
  1120. <p class="admonition-title">Warning</p>
  1121. <p><em>Do not</em> call <code class="docutils literal notranslate"><span class="pre">super().__new__()</span></code>, as the lookup-only <code class="docutils literal notranslate"><span class="pre">__new__</span></code> is the one
  1122. that is found; instead, use the data type directly.</p>
  1123. </div>
  1124. <section id="finer-points">
  1125. <h3>Finer Points<a class="headerlink" href="#finer-points" title="Link to this heading">¶</a></h3>
  1126. <section id="supported-dunder-names">
  1127. <h4>Supported <code class="docutils literal notranslate"><span class="pre">__dunder__</span></code> names<a class="headerlink" href="#supported-dunder-names" title="Link to this heading">¶</a></h4>
  1128. <p><code class="xref py py-attr docutils literal notranslate"><span class="pre">__members__</span></code> is a read-only ordered mapping of <code class="docutils literal notranslate"><span class="pre">member_name</span></code>:<code class="docutils literal notranslate"><span class="pre">member</span></code>
  1129. items. It is only available on the class.</p>
  1130. <p><code class="xref py py-meth docutils literal notranslate"><span class="pre">__new__()</span></code>, if specified, must create and return the enum members; it is
  1131. also a very good idea to set the member’s <code class="xref py py-attr docutils literal notranslate"><span class="pre">_value_</span></code> appropriately. Once
  1132. all the members are created it is no longer used.</p>
  1133. </section>
  1134. <section id="supported-sunder-names">
  1135. <h4>Supported <code class="docutils literal notranslate"><span class="pre">_sunder_</span></code> names<a class="headerlink" href="#supported-sunder-names" title="Link to this heading">¶</a></h4>
  1136. <ul class="simple">
  1137. <li><p><code class="docutils literal notranslate"><span class="pre">_name_</span></code> – name of the member</p></li>
  1138. <li><p><code class="docutils literal notranslate"><span class="pre">_value_</span></code> – value of the member; can be set / modified in <code class="docutils literal notranslate"><span class="pre">__new__</span></code></p></li>
  1139. <li><p><code class="docutils literal notranslate"><span class="pre">_missing_</span></code> – a lookup function used when a value is not found; may be
  1140. overridden</p></li>
  1141. <li><p><code class="docutils literal notranslate"><span class="pre">_ignore_</span></code> – a list of names, either as a <a class="reference internal" href="../library/stdtypes.html#list" title="list"><code class="xref py py-class docutils literal notranslate"><span class="pre">list</span></code></a> or a <a class="reference internal" href="../library/stdtypes.html#str" title="str"><code class="xref py py-class docutils literal notranslate"><span class="pre">str</span></code></a>,
  1142. that will not be transformed into members, and will be removed from the final
  1143. class</p></li>
  1144. <li><p><code class="docutils literal notranslate"><span class="pre">_order_</span></code> – used in Python 2/3 code to ensure member order is consistent
  1145. (class attribute, removed during class creation)</p></li>
  1146. <li><p><code class="docutils literal notranslate"><span class="pre">_generate_next_value_</span></code> – used by the <a class="reference internal" href="#functional-api">Functional API</a> and by
  1147. <a class="reference internal" href="../library/enum.html#enum.auto" title="enum.auto"><code class="xref py py-class docutils literal notranslate"><span class="pre">auto</span></code></a> to get an appropriate value for an enum member; may be
  1148. overridden</p></li>
  1149. </ul>
  1150. <div class="admonition note">
  1151. <p class="admonition-title">Note</p>
  1152. <p>For standard <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> classes the next value chosen is the last value seen
  1153. incremented by one.</p>
  1154. <p>For <a class="reference internal" href="../library/enum.html#enum.Flag" title="enum.Flag"><code class="xref py py-class docutils literal notranslate"><span class="pre">Flag</span></code></a> classes the next value chosen will be the next highest
  1155. power-of-two, regardless of the last value seen.</p>
  1156. </div>
  1157. <div class="versionadded">
  1158. <p><span class="versionmodified added">New in version 3.6: </span><code class="docutils literal notranslate"><span class="pre">_missing_</span></code>, <code class="docutils literal notranslate"><span class="pre">_order_</span></code>, <code class="docutils literal notranslate"><span class="pre">_generate_next_value_</span></code></p>
  1159. </div>
  1160. <div class="versionadded">
  1161. <p><span class="versionmodified added">New in version 3.7: </span><code class="docutils literal notranslate"><span class="pre">_ignore_</span></code></p>
  1162. </div>
  1163. <p>To help keep Python 2 / Python 3 code in sync an <code class="xref py py-attr docutils literal notranslate"><span class="pre">_order_</span></code> attribute can
  1164. be provided. It will be checked against the actual order of the enumeration
  1165. and raise an error if the two do not match:</p>
  1166. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Color</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  1167. <span class="gp">... </span> <span class="n">_order_</span> <span class="o">=</span> <span class="s1">&#39;RED GREEN BLUE&#39;</span>
  1168. <span class="gp">... </span> <span class="n">RED</span> <span class="o">=</span> <span class="mi">1</span>
  1169. <span class="gp">... </span> <span class="n">BLUE</span> <span class="o">=</span> <span class="mi">3</span>
  1170. <span class="gp">... </span> <span class="n">GREEN</span> <span class="o">=</span> <span class="mi">2</span>
  1171. <span class="gp">...</span>
  1172. <span class="gt">Traceback (most recent call last):</span>
  1173. <span class="c">...</span>
  1174. <span class="gr">TypeError</span>: <span class="n">member order does not match _order_:</span>
  1175. <span class="x"> [&#39;RED&#39;, &#39;BLUE&#39;, &#39;GREEN&#39;]</span>
  1176. <span class="x"> [&#39;RED&#39;, &#39;GREEN&#39;, &#39;BLUE&#39;]</span>
  1177. </pre></div>
  1178. </div>
  1179. <div class="admonition note">
  1180. <p class="admonition-title">Note</p>
  1181. <p>In Python 2 code the <code class="xref py py-attr docutils literal notranslate"><span class="pre">_order_</span></code> attribute is necessary as definition
  1182. order is lost before it can be recorded.</p>
  1183. </div>
  1184. </section>
  1185. <section id="private-names">
  1186. <h4>_Private__names<a class="headerlink" href="#private-names" title="Link to this heading">¶</a></h4>
  1187. <p><a class="reference internal" href="../reference/expressions.html#private-name-mangling"><span class="std std-ref">Private names</span></a> are not converted to enum members,
  1188. but remain normal attributes.</p>
  1189. <div class="versionchanged">
  1190. <p><span class="versionmodified changed">Changed in version 3.11.</span></p>
  1191. </div>
  1192. </section>
  1193. <section id="enum-member-type">
  1194. <h4><code class="docutils literal notranslate"><span class="pre">Enum</span></code> member type<a class="headerlink" href="#enum-member-type" title="Link to this heading">¶</a></h4>
  1195. <p>Enum members are instances of their enum class, and are normally accessed as
  1196. <code class="docutils literal notranslate"><span class="pre">EnumClass.member</span></code>. In certain situations, such as writing custom enum
  1197. behavior, being able to access one member directly from another is useful,
  1198. and is supported; however, in order to avoid name clashes between member names
  1199. and attributes/methods from mixed-in classes, upper-case names are strongly
  1200. recommended.</p>
  1201. <div class="versionchanged">
  1202. <p><span class="versionmodified changed">Changed in version 3.5.</span></p>
  1203. </div>
  1204. </section>
  1205. <section id="creating-members-that-are-mixed-with-other-data-types">
  1206. <h4>Creating members that are mixed with other data types<a class="headerlink" href="#creating-members-that-are-mixed-with-other-data-types" title="Link to this heading">¶</a></h4>
  1207. <p>When subclassing other data types, such as <a class="reference internal" href="../library/functions.html#int" title="int"><code class="xref py py-class docutils literal notranslate"><span class="pre">int</span></code></a> or <a class="reference internal" href="../library/stdtypes.html#str" title="str"><code class="xref py py-class docutils literal notranslate"><span class="pre">str</span></code></a>, with
  1208. an <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a>, all values after the <code class="docutils literal notranslate"><span class="pre">=</span></code> are passed to that data type’s
  1209. constructor. For example:</p>
  1210. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">MyEnum</span><span class="p">(</span><span class="n">IntEnum</span><span class="p">):</span> <span class="c1"># help(int) -&gt; int(x, base=10) -&gt; integer</span>
  1211. <span class="gp">... </span> <span class="n">example</span> <span class="o">=</span> <span class="s1">&#39;11&#39;</span><span class="p">,</span> <span class="mi">16</span> <span class="c1"># so x=&#39;11&#39; and base=16</span>
  1212. <span class="gp">...</span>
  1213. <span class="gp">&gt;&gt;&gt; </span><span class="n">MyEnum</span><span class="o">.</span><span class="n">example</span><span class="o">.</span><span class="n">value</span> <span class="c1"># and hex(11) is...</span>
  1214. <span class="go">17</span>
  1215. </pre></div>
  1216. </div>
  1217. </section>
  1218. <section id="boolean-value-of-enum-classes-and-members">
  1219. <h4>Boolean value of <code class="docutils literal notranslate"><span class="pre">Enum</span></code> classes and members<a class="headerlink" href="#boolean-value-of-enum-classes-and-members" title="Link to this heading">¶</a></h4>
  1220. <p>Enum classes that are mixed with non-<a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> types (such as
  1221. <a class="reference internal" href="../library/functions.html#int" title="int"><code class="xref py py-class docutils literal notranslate"><span class="pre">int</span></code></a>, <a class="reference internal" href="../library/stdtypes.html#str" title="str"><code class="xref py py-class docutils literal notranslate"><span class="pre">str</span></code></a>, etc.) are evaluated according to the mixed-in
  1222. type’s rules; otherwise, all members evaluate as <a class="reference internal" href="../library/constants.html#True" title="True"><code class="xref py py-data docutils literal notranslate"><span class="pre">True</span></code></a>. To make your
  1223. own enum’s boolean evaluation depend on the member’s value add the following to
  1224. your class:</p>
  1225. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="k">def</span> <span class="fm">__bool__</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
  1226. <span class="k">return</span> <span class="nb">bool</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">value</span><span class="p">)</span>
  1227. </pre></div>
  1228. </div>
  1229. <p>Plain <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> classes always evaluate as <a class="reference internal" href="../library/constants.html#True" title="True"><code class="xref py py-data docutils literal notranslate"><span class="pre">True</span></code></a>.</p>
  1230. </section>
  1231. <section id="enum-classes-with-methods">
  1232. <h4><code class="docutils literal notranslate"><span class="pre">Enum</span></code> classes with methods<a class="headerlink" href="#enum-classes-with-methods" title="Link to this heading">¶</a></h4>
  1233. <p>If you give your enum subclass extra methods, like the <a class="reference internal" href="#planet">Planet</a>
  1234. class below, those methods will show up in a <a class="reference internal" href="../library/functions.html#dir" title="dir"><code class="xref py py-func docutils literal notranslate"><span class="pre">dir()</span></code></a> of the member,
  1235. but not of the class:</p>
  1236. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="nb">dir</span><span class="p">(</span><span class="n">Planet</span><span class="p">)</span>
  1237. <span class="go">[&#39;EARTH&#39;, &#39;JUPITER&#39;, &#39;MARS&#39;, &#39;MERCURY&#39;, &#39;NEPTUNE&#39;, &#39;SATURN&#39;, &#39;URANUS&#39;, &#39;VENUS&#39;, &#39;__class__&#39;, &#39;__doc__&#39;, &#39;__members__&#39;, &#39;__module__&#39;]</span>
  1238. <span class="gp">&gt;&gt;&gt; </span><span class="nb">dir</span><span class="p">(</span><span class="n">Planet</span><span class="o">.</span><span class="n">EARTH</span><span class="p">)</span>
  1239. <span class="go">[&#39;__class__&#39;, &#39;__doc__&#39;, &#39;__module__&#39;, &#39;mass&#39;, &#39;name&#39;, &#39;radius&#39;, &#39;surface_gravity&#39;, &#39;value&#39;]</span>
  1240. </pre></div>
  1241. </div>
  1242. </section>
  1243. <section id="combining-members-of-flag">
  1244. <h4>Combining members of <code class="docutils literal notranslate"><span class="pre">Flag</span></code><a class="headerlink" href="#combining-members-of-flag" title="Link to this heading">¶</a></h4>
  1245. <p>Iterating over a combination of <a class="reference internal" href="../library/enum.html#enum.Flag" title="enum.Flag"><code class="xref py py-class docutils literal notranslate"><span class="pre">Flag</span></code></a> members will only return the members that
  1246. are comprised of a single bit:</p>
  1247. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Color</span><span class="p">(</span><span class="n">Flag</span><span class="p">):</span>
  1248. <span class="gp">... </span> <span class="n">RED</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  1249. <span class="gp">... </span> <span class="n">GREEN</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  1250. <span class="gp">... </span> <span class="n">BLUE</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  1251. <span class="gp">... </span> <span class="n">MAGENTA</span> <span class="o">=</span> <span class="n">RED</span> <span class="o">|</span> <span class="n">BLUE</span>
  1252. <span class="gp">... </span> <span class="n">YELLOW</span> <span class="o">=</span> <span class="n">RED</span> <span class="o">|</span> <span class="n">GREEN</span>
  1253. <span class="gp">... </span> <span class="n">CYAN</span> <span class="o">=</span> <span class="n">GREEN</span> <span class="o">|</span> <span class="n">BLUE</span>
  1254. <span class="gp">...</span>
  1255. <span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="p">(</span><span class="mi">3</span><span class="p">)</span> <span class="c1"># named combination</span>
  1256. <span class="go">&lt;Color.YELLOW: 3&gt;</span>
  1257. <span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="p">(</span><span class="mi">7</span><span class="p">)</span> <span class="c1"># not named combination</span>
  1258. <span class="go">&lt;Color.RED|GREEN|BLUE: 7&gt;</span>
  1259. </pre></div>
  1260. </div>
  1261. </section>
  1262. <section id="flag-and-intflag-minutia">
  1263. <h4><code class="docutils literal notranslate"><span class="pre">Flag</span></code> and <code class="docutils literal notranslate"><span class="pre">IntFlag</span></code> minutia<a class="headerlink" href="#flag-and-intflag-minutia" title="Link to this heading">¶</a></h4>
  1264. <p>Using the following snippet for our examples:</p>
  1265. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Color</span><span class="p">(</span><span class="n">IntFlag</span><span class="p">):</span>
  1266. <span class="gp">... </span> <span class="n">BLACK</span> <span class="o">=</span> <span class="mi">0</span>
  1267. <span class="gp">... </span> <span class="n">RED</span> <span class="o">=</span> <span class="mi">1</span>
  1268. <span class="gp">... </span> <span class="n">GREEN</span> <span class="o">=</span> <span class="mi">2</span>
  1269. <span class="gp">... </span> <span class="n">BLUE</span> <span class="o">=</span> <span class="mi">4</span>
  1270. <span class="gp">... </span> <span class="n">PURPLE</span> <span class="o">=</span> <span class="n">RED</span> <span class="o">|</span> <span class="n">BLUE</span>
  1271. <span class="gp">... </span> <span class="n">WHITE</span> <span class="o">=</span> <span class="n">RED</span> <span class="o">|</span> <span class="n">GREEN</span> <span class="o">|</span> <span class="n">BLUE</span>
  1272. <span class="gp">...</span>
  1273. </pre></div>
  1274. </div>
  1275. <p>the following are true:</p>
  1276. <ul>
  1277. <li><p>single-bit flags are canonical</p></li>
  1278. <li><p>multi-bit and zero-bit flags are aliases</p></li>
  1279. <li><p>only canonical flags are returned during iteration:</p>
  1280. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="nb">list</span><span class="p">(</span><span class="n">Color</span><span class="o">.</span><span class="n">WHITE</span><span class="p">)</span>
  1281. <span class="go">[&lt;Color.RED: 1&gt;, &lt;Color.GREEN: 2&gt;, &lt;Color.BLUE: 4&gt;]</span>
  1282. </pre></div>
  1283. </div>
  1284. </li>
  1285. <li><p>negating a flag or flag set returns a new flag/flag set with the
  1286. corresponding positive integer value:</p>
  1287. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">BLUE</span>
  1288. <span class="go">&lt;Color.BLUE: 4&gt;</span>
  1289. <span class="gp">&gt;&gt;&gt; </span><span class="o">~</span><span class="n">Color</span><span class="o">.</span><span class="n">BLUE</span>
  1290. <span class="go">&lt;Color.RED|GREEN: 3&gt;</span>
  1291. </pre></div>
  1292. </div>
  1293. </li>
  1294. <li><p>names of pseudo-flags are constructed from their members’ names:</p>
  1295. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="p">(</span><span class="n">Color</span><span class="o">.</span><span class="n">RED</span> <span class="o">|</span> <span class="n">Color</span><span class="o">.</span><span class="n">GREEN</span><span class="p">)</span><span class="o">.</span><span class="n">name</span>
  1296. <span class="go">&#39;RED|GREEN&#39;</span>
  1297. </pre></div>
  1298. </div>
  1299. </li>
  1300. <li><p>multi-bit flags, aka aliases, can be returned from operations:</p>
  1301. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">RED</span> <span class="o">|</span> <span class="n">Color</span><span class="o">.</span><span class="n">BLUE</span>
  1302. <span class="go">&lt;Color.PURPLE: 5&gt;</span>
  1303. <span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="p">(</span><span class="mi">7</span><span class="p">)</span> <span class="c1"># or Color(-1)</span>
  1304. <span class="go">&lt;Color.WHITE: 7&gt;</span>
  1305. <span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="p">(</span><span class="mi">0</span><span class="p">)</span>
  1306. <span class="go">&lt;Color.BLACK: 0&gt;</span>
  1307. </pre></div>
  1308. </div>
  1309. </li>
  1310. <li><p>membership / containment checking: zero-valued flags are always considered
  1311. to be contained:</p>
  1312. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">BLACK</span> <span class="ow">in</span> <span class="n">Color</span><span class="o">.</span><span class="n">WHITE</span>
  1313. <span class="go">True</span>
  1314. </pre></div>
  1315. </div>
  1316. <p>otherwise, only if all bits of one flag are in the other flag will True
  1317. be returned:</p>
  1318. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">PURPLE</span> <span class="ow">in</span> <span class="n">Color</span><span class="o">.</span><span class="n">WHITE</span>
  1319. <span class="go">True</span>
  1320. <span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">GREEN</span> <span class="ow">in</span> <span class="n">Color</span><span class="o">.</span><span class="n">PURPLE</span>
  1321. <span class="go">False</span>
  1322. </pre></div>
  1323. </div>
  1324. </li>
  1325. </ul>
  1326. <p>There is a new boundary mechanism that controls how out-of-range / invalid
  1327. bits are handled: <code class="docutils literal notranslate"><span class="pre">STRICT</span></code>, <code class="docutils literal notranslate"><span class="pre">CONFORM</span></code>, <code class="docutils literal notranslate"><span class="pre">EJECT</span></code>, and <code class="docutils literal notranslate"><span class="pre">KEEP</span></code>:</p>
  1328. <ul class="simple">
  1329. <li><p>STRICT –&gt; raises an exception when presented with invalid values</p></li>
  1330. <li><p>CONFORM –&gt; discards any invalid bits</p></li>
  1331. <li><p>EJECT –&gt; lose Flag status and become a normal int with the given value</p></li>
  1332. <li><p>KEEP –&gt; keep the extra bits</p>
  1333. <ul>
  1334. <li><p>keeps Flag status and extra bits</p></li>
  1335. <li><p>extra bits do not show up in iteration</p></li>
  1336. <li><p>extra bits do show up in repr() and str()</p></li>
  1337. </ul>
  1338. </li>
  1339. </ul>
  1340. <p>The default for Flag is <code class="docutils literal notranslate"><span class="pre">STRICT</span></code>, the default for <code class="docutils literal notranslate"><span class="pre">IntFlag</span></code> is <code class="docutils literal notranslate"><span class="pre">EJECT</span></code>,
  1341. and the default for <code class="docutils literal notranslate"><span class="pre">_convert_</span></code> is <code class="docutils literal notranslate"><span class="pre">KEEP</span></code> (see <code class="docutils literal notranslate"><span class="pre">ssl.Options</span></code> for an
  1342. example of when <code class="docutils literal notranslate"><span class="pre">KEEP</span></code> is needed).</p>
  1343. </section>
  1344. </section>
  1345. </section>
  1346. <section id="how-are-enums-and-flags-different">
  1347. <span id="enum-class-differences"></span><h2>How are Enums and Flags different?<a class="headerlink" href="#how-are-enums-and-flags-different" title="Link to this heading">¶</a></h2>
  1348. <p>Enums have a custom metaclass that affects many aspects of both derived <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a>
  1349. classes and their instances (members).</p>
  1350. <section id="enum-classes">
  1351. <h3>Enum Classes<a class="headerlink" href="#enum-classes" title="Link to this heading">¶</a></h3>
  1352. <p>The <a class="reference internal" href="../library/enum.html#enum.EnumType" title="enum.EnumType"><code class="xref py py-class docutils literal notranslate"><span class="pre">EnumType</span></code></a> metaclass is responsible for providing the
  1353. <code class="xref py py-meth docutils literal notranslate"><span class="pre">__contains__()</span></code>, <code class="xref py py-meth docutils literal notranslate"><span class="pre">__dir__()</span></code>, <code class="xref py py-meth docutils literal notranslate"><span class="pre">__iter__()</span></code> and other methods that
  1354. allow one to do things with an <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> class that fail on a typical
  1355. class, such as <code class="docutils literal notranslate"><span class="pre">list(Color)</span></code> or <code class="docutils literal notranslate"><span class="pre">some_enum_var</span> <span class="pre">in</span> <span class="pre">Color</span></code>. <a class="reference internal" href="../library/enum.html#enum.EnumType" title="enum.EnumType"><code class="xref py py-class docutils literal notranslate"><span class="pre">EnumType</span></code></a> is
  1356. responsible for ensuring that various other methods on the final <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a>
  1357. class are correct (such as <code class="xref py py-meth docutils literal notranslate"><span class="pre">__new__()</span></code>, <code class="xref py py-meth docutils literal notranslate"><span class="pre">__getnewargs__()</span></code>,
  1358. <code class="xref py py-meth docutils literal notranslate"><span class="pre">__str__()</span></code> and <code class="xref py py-meth docutils literal notranslate"><span class="pre">__repr__()</span></code>).</p>
  1359. </section>
  1360. <section id="flag-classes">
  1361. <h3>Flag Classes<a class="headerlink" href="#flag-classes" title="Link to this heading">¶</a></h3>
  1362. <p>Flags have an expanded view of aliasing: to be canonical, the value of a flag
  1363. needs to be a power-of-two value, and not a duplicate name. So, in addition to the
  1364. <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> definition of alias, a flag with no value (a.k.a. <code class="docutils literal notranslate"><span class="pre">0</span></code>) or with more than one
  1365. power-of-two value (e.g. <code class="docutils literal notranslate"><span class="pre">3</span></code>) is considered an alias.</p>
  1366. </section>
  1367. <section id="enum-members-aka-instances">
  1368. <h3>Enum Members (aka instances)<a class="headerlink" href="#enum-members-aka-instances" title="Link to this heading">¶</a></h3>
  1369. <p>The most interesting thing about enum members is that they are singletons.
  1370. <a class="reference internal" href="../library/enum.html#enum.EnumType" title="enum.EnumType"><code class="xref py py-class docutils literal notranslate"><span class="pre">EnumType</span></code></a> creates them all while it is creating the enum class itself,
  1371. and then puts a custom <code class="xref py py-meth docutils literal notranslate"><span class="pre">__new__()</span></code> in place to ensure that no new ones are
  1372. ever instantiated by returning only the existing member instances.</p>
  1373. </section>
  1374. <section id="flag-members">
  1375. <h3>Flag Members<a class="headerlink" href="#flag-members" title="Link to this heading">¶</a></h3>
  1376. <p>Flag members can be iterated over just like the <a class="reference internal" href="../library/enum.html#enum.Flag" title="enum.Flag"><code class="xref py py-class docutils literal notranslate"><span class="pre">Flag</span></code></a> class, and only the
  1377. canonical members will be returned. For example:</p>
  1378. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="nb">list</span><span class="p">(</span><span class="n">Color</span><span class="p">)</span>
  1379. <span class="go">[&lt;Color.RED: 1&gt;, &lt;Color.GREEN: 2&gt;, &lt;Color.BLUE: 4&gt;]</span>
  1380. </pre></div>
  1381. </div>
  1382. <p>(Note that <code class="docutils literal notranslate"><span class="pre">BLACK</span></code>, <code class="docutils literal notranslate"><span class="pre">PURPLE</span></code>, and <code class="docutils literal notranslate"><span class="pre">WHITE</span></code> do not show up.)</p>
  1383. <p>Inverting a flag member returns the corresponding positive value,
  1384. rather than a negative value — for example:</p>
  1385. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="o">~</span><span class="n">Color</span><span class="o">.</span><span class="n">RED</span>
  1386. <span class="go">&lt;Color.GREEN|BLUE: 6&gt;</span>
  1387. </pre></div>
  1388. </div>
  1389. <p>Flag members have a length corresponding to the number of power-of-two values
  1390. they contain. For example:</p>
  1391. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="nb">len</span><span class="p">(</span><span class="n">Color</span><span class="o">.</span><span class="n">PURPLE</span><span class="p">)</span>
  1392. <span class="go">2</span>
  1393. </pre></div>
  1394. </div>
  1395. </section>
  1396. </section>
  1397. <section id="enum-cookbook">
  1398. <span id="id1"></span><h2>Enum Cookbook<a class="headerlink" href="#enum-cookbook" title="Link to this heading">¶</a></h2>
  1399. <p>While <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a>, <a class="reference internal" href="../library/enum.html#enum.IntEnum" title="enum.IntEnum"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntEnum</span></code></a>, <a class="reference internal" href="../library/enum.html#enum.StrEnum" title="enum.StrEnum"><code class="xref py py-class docutils literal notranslate"><span class="pre">StrEnum</span></code></a>, <a class="reference internal" href="../library/enum.html#enum.Flag" title="enum.Flag"><code class="xref py py-class docutils literal notranslate"><span class="pre">Flag</span></code></a>, and
  1400. <a class="reference internal" href="../library/enum.html#enum.IntFlag" title="enum.IntFlag"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntFlag</span></code></a> are expected to cover the majority of use-cases, they cannot
  1401. cover them all. Here are recipes for some different types of enumerations
  1402. that can be used directly, or as examples for creating one’s own.</p>
  1403. <section id="omitting-values">
  1404. <h3>Omitting values<a class="headerlink" href="#omitting-values" title="Link to this heading">¶</a></h3>
  1405. <p>In many use-cases, one doesn’t care what the actual value of an enumeration
  1406. is. There are several ways to define this type of simple enumeration:</p>
  1407. <ul class="simple">
  1408. <li><p>use instances of <a class="reference internal" href="../library/enum.html#enum.auto" title="enum.auto"><code class="xref py py-class docutils literal notranslate"><span class="pre">auto</span></code></a> for the value</p></li>
  1409. <li><p>use instances of <a class="reference internal" href="../library/functions.html#object" title="object"><code class="xref py py-class docutils literal notranslate"><span class="pre">object</span></code></a> as the value</p></li>
  1410. <li><p>use a descriptive string as the value</p></li>
  1411. <li><p>use a tuple as the value and a custom <code class="xref py py-meth docutils literal notranslate"><span class="pre">__new__()</span></code> to replace the
  1412. tuple with an <a class="reference internal" href="../library/functions.html#int" title="int"><code class="xref py py-class docutils literal notranslate"><span class="pre">int</span></code></a> value</p></li>
  1413. </ul>
  1414. <p>Using any of these methods signifies to the user that these values are not
  1415. important, and also enables one to add, remove, or reorder members without
  1416. having to renumber the remaining members.</p>
  1417. <section id="using-auto">
  1418. <h4>Using <a class="reference internal" href="../library/enum.html#enum.auto" title="enum.auto"><code class="xref py py-class docutils literal notranslate"><span class="pre">auto</span></code></a><a class="headerlink" href="#using-auto" title="Link to this heading">¶</a></h4>
  1419. <p>Using <a class="reference internal" href="../library/enum.html#enum.auto" title="enum.auto"><code class="xref py py-class docutils literal notranslate"><span class="pre">auto</span></code></a> would look like:</p>
  1420. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Color</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  1421. <span class="gp">... </span> <span class="n">RED</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  1422. <span class="gp">... </span> <span class="n">BLUE</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  1423. <span class="gp">... </span> <span class="n">GREEN</span> <span class="o">=</span> <span class="n">auto</span><span class="p">()</span>
  1424. <span class="gp">...</span>
  1425. <span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">GREEN</span>
  1426. <span class="go">&lt;Color.GREEN: 3&gt;</span>
  1427. </pre></div>
  1428. </div>
  1429. </section>
  1430. <section id="using-object">
  1431. <h4>Using <a class="reference internal" href="../library/functions.html#object" title="object"><code class="xref py py-class docutils literal notranslate"><span class="pre">object</span></code></a><a class="headerlink" href="#using-object" title="Link to this heading">¶</a></h4>
  1432. <p>Using <a class="reference internal" href="../library/functions.html#object" title="object"><code class="xref py py-class docutils literal notranslate"><span class="pre">object</span></code></a> would look like:</p>
  1433. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Color</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  1434. <span class="gp">... </span> <span class="n">RED</span> <span class="o">=</span> <span class="nb">object</span><span class="p">()</span>
  1435. <span class="gp">... </span> <span class="n">GREEN</span> <span class="o">=</span> <span class="nb">object</span><span class="p">()</span>
  1436. <span class="gp">... </span> <span class="n">BLUE</span> <span class="o">=</span> <span class="nb">object</span><span class="p">()</span>
  1437. <span class="gp">...</span>
  1438. <span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">GREEN</span>
  1439. <span class="go">&lt;Color.GREEN: &lt;object object at 0x...&gt;&gt;</span>
  1440. </pre></div>
  1441. </div>
  1442. <p>This is also a good example of why you might want to write your own
  1443. <code class="xref py py-meth docutils literal notranslate"><span class="pre">__repr__()</span></code>:</p>
  1444. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Color</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  1445. <span class="gp">... </span> <span class="n">RED</span> <span class="o">=</span> <span class="nb">object</span><span class="p">()</span>
  1446. <span class="gp">... </span> <span class="n">GREEN</span> <span class="o">=</span> <span class="nb">object</span><span class="p">()</span>
  1447. <span class="gp">... </span> <span class="n">BLUE</span> <span class="o">=</span> <span class="nb">object</span><span class="p">()</span>
  1448. <span class="gp">... </span> <span class="k">def</span> <span class="fm">__repr__</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
  1449. <span class="gp">... </span> <span class="k">return</span> <span class="s2">&quot;&lt;</span><span class="si">%s</span><span class="s2">.</span><span class="si">%s</span><span class="s2">&gt;&quot;</span> <span class="o">%</span> <span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="vm">__class__</span><span class="o">.</span><span class="vm">__name__</span><span class="p">,</span> <span class="bp">self</span><span class="o">.</span><span class="n">_name_</span><span class="p">)</span>
  1450. <span class="gp">...</span>
  1451. <span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">GREEN</span>
  1452. <span class="go">&lt;Color.GREEN&gt;</span>
  1453. </pre></div>
  1454. </div>
  1455. </section>
  1456. <section id="using-a-descriptive-string">
  1457. <h4>Using a descriptive string<a class="headerlink" href="#using-a-descriptive-string" title="Link to this heading">¶</a></h4>
  1458. <p>Using a string as the value would look like:</p>
  1459. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Color</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  1460. <span class="gp">... </span> <span class="n">RED</span> <span class="o">=</span> <span class="s1">&#39;stop&#39;</span>
  1461. <span class="gp">... </span> <span class="n">GREEN</span> <span class="o">=</span> <span class="s1">&#39;go&#39;</span>
  1462. <span class="gp">... </span> <span class="n">BLUE</span> <span class="o">=</span> <span class="s1">&#39;too fast!&#39;</span>
  1463. <span class="gp">...</span>
  1464. <span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">GREEN</span>
  1465. <span class="go">&lt;Color.GREEN: &#39;go&#39;&gt;</span>
  1466. </pre></div>
  1467. </div>
  1468. </section>
  1469. <section id="using-a-custom-new">
  1470. <h4>Using a custom <code class="xref py py-meth docutils literal notranslate"><span class="pre">__new__()</span></code><a class="headerlink" href="#using-a-custom-new" title="Link to this heading">¶</a></h4>
  1471. <p>Using an auto-numbering <code class="xref py py-meth docutils literal notranslate"><span class="pre">__new__()</span></code> would look like:</p>
  1472. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">AutoNumber</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  1473. <span class="gp">... </span> <span class="k">def</span> <span class="fm">__new__</span><span class="p">(</span><span class="bp">cls</span><span class="p">):</span>
  1474. <span class="gp">... </span> <span class="n">value</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="bp">cls</span><span class="o">.</span><span class="n">__members__</span><span class="p">)</span> <span class="o">+</span> <span class="mi">1</span>
  1475. <span class="gp">... </span> <span class="n">obj</span> <span class="o">=</span> <span class="nb">object</span><span class="o">.</span><span class="fm">__new__</span><span class="p">(</span><span class="bp">cls</span><span class="p">)</span>
  1476. <span class="gp">... </span> <span class="n">obj</span><span class="o">.</span><span class="n">_value_</span> <span class="o">=</span> <span class="n">value</span>
  1477. <span class="gp">... </span> <span class="k">return</span> <span class="n">obj</span>
  1478. <span class="gp">...</span>
  1479. <span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Color</span><span class="p">(</span><span class="n">AutoNumber</span><span class="p">):</span>
  1480. <span class="gp">... </span> <span class="n">RED</span> <span class="o">=</span> <span class="p">()</span>
  1481. <span class="gp">... </span> <span class="n">GREEN</span> <span class="o">=</span> <span class="p">()</span>
  1482. <span class="gp">... </span> <span class="n">BLUE</span> <span class="o">=</span> <span class="p">()</span>
  1483. <span class="gp">...</span>
  1484. <span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">GREEN</span>
  1485. <span class="go">&lt;Color.GREEN: 2&gt;</span>
  1486. </pre></div>
  1487. </div>
  1488. <p>To make a more general purpose <code class="docutils literal notranslate"><span class="pre">AutoNumber</span></code>, add <code class="docutils literal notranslate"><span class="pre">*args</span></code> to the signature:</p>
  1489. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">AutoNumber</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  1490. <span class="gp">... </span> <span class="k">def</span> <span class="fm">__new__</span><span class="p">(</span><span class="bp">cls</span><span class="p">,</span> <span class="o">*</span><span class="n">args</span><span class="p">):</span> <span class="c1"># this is the only change from above</span>
  1491. <span class="gp">... </span> <span class="n">value</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="bp">cls</span><span class="o">.</span><span class="n">__members__</span><span class="p">)</span> <span class="o">+</span> <span class="mi">1</span>
  1492. <span class="gp">... </span> <span class="n">obj</span> <span class="o">=</span> <span class="nb">object</span><span class="o">.</span><span class="fm">__new__</span><span class="p">(</span><span class="bp">cls</span><span class="p">)</span>
  1493. <span class="gp">... </span> <span class="n">obj</span><span class="o">.</span><span class="n">_value_</span> <span class="o">=</span> <span class="n">value</span>
  1494. <span class="gp">... </span> <span class="k">return</span> <span class="n">obj</span>
  1495. <span class="gp">...</span>
  1496. </pre></div>
  1497. </div>
  1498. <p>Then when you inherit from <code class="docutils literal notranslate"><span class="pre">AutoNumber</span></code> you can write your own <code class="docutils literal notranslate"><span class="pre">__init__</span></code>
  1499. to handle any extra arguments:</p>
  1500. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Swatch</span><span class="p">(</span><span class="n">AutoNumber</span><span class="p">):</span>
  1501. <span class="gp">... </span> <span class="k">def</span> <span class="fm">__init__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">pantone</span><span class="o">=</span><span class="s1">&#39;unknown&#39;</span><span class="p">):</span>
  1502. <span class="gp">... </span> <span class="bp">self</span><span class="o">.</span><span class="n">pantone</span> <span class="o">=</span> <span class="n">pantone</span>
  1503. <span class="gp">... </span> <span class="n">AUBURN</span> <span class="o">=</span> <span class="s1">&#39;3497&#39;</span>
  1504. <span class="gp">... </span> <span class="n">SEA_GREEN</span> <span class="o">=</span> <span class="s1">&#39;1246&#39;</span>
  1505. <span class="gp">... </span> <span class="n">BLEACHED_CORAL</span> <span class="o">=</span> <span class="p">()</span> <span class="c1"># New color, no Pantone code yet!</span>
  1506. <span class="gp">...</span>
  1507. <span class="gp">&gt;&gt;&gt; </span><span class="n">Swatch</span><span class="o">.</span><span class="n">SEA_GREEN</span>
  1508. <span class="go">&lt;Swatch.SEA_GREEN: 2&gt;</span>
  1509. <span class="gp">&gt;&gt;&gt; </span><span class="n">Swatch</span><span class="o">.</span><span class="n">SEA_GREEN</span><span class="o">.</span><span class="n">pantone</span>
  1510. <span class="go">&#39;1246&#39;</span>
  1511. <span class="gp">&gt;&gt;&gt; </span><span class="n">Swatch</span><span class="o">.</span><span class="n">BLEACHED_CORAL</span><span class="o">.</span><span class="n">pantone</span>
  1512. <span class="go">&#39;unknown&#39;</span>
  1513. </pre></div>
  1514. </div>
  1515. <div class="admonition note">
  1516. <p class="admonition-title">Note</p>
  1517. <p>The <code class="xref py py-meth docutils literal notranslate"><span class="pre">__new__()</span></code> method, if defined, is used during creation of the Enum
  1518. members; it is then replaced by Enum’s <code class="xref py py-meth docutils literal notranslate"><span class="pre">__new__()</span></code> which is used after
  1519. class creation for lookup of existing members.</p>
  1520. </div>
  1521. <div class="admonition warning">
  1522. <p class="admonition-title">Warning</p>
  1523. <p><em>Do not</em> call <code class="docutils literal notranslate"><span class="pre">super().__new__()</span></code>, as the lookup-only <code class="docutils literal notranslate"><span class="pre">__new__</span></code> is the one
  1524. that is found; instead, use the data type directly – e.g.:</p>
  1525. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="n">obj</span> <span class="o">=</span> <span class="nb">int</span><span class="o">.</span><span class="fm">__new__</span><span class="p">(</span><span class="bp">cls</span><span class="p">,</span> <span class="n">value</span><span class="p">)</span>
  1526. </pre></div>
  1527. </div>
  1528. </div>
  1529. </section>
  1530. </section>
  1531. <section id="orderedenum">
  1532. <h3>OrderedEnum<a class="headerlink" href="#orderedenum" title="Link to this heading">¶</a></h3>
  1533. <p>An ordered enumeration that is not based on <a class="reference internal" href="../library/enum.html#enum.IntEnum" title="enum.IntEnum"><code class="xref py py-class docutils literal notranslate"><span class="pre">IntEnum</span></code></a> and so maintains
  1534. the normal <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> invariants (such as not being comparable to other
  1535. enumerations):</p>
  1536. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">OrderedEnum</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  1537. <span class="gp">... </span> <span class="k">def</span> <span class="fm">__ge__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">other</span><span class="p">):</span>
  1538. <span class="gp">... </span> <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="vm">__class__</span> <span class="ow">is</span> <span class="n">other</span><span class="o">.</span><span class="vm">__class__</span><span class="p">:</span>
  1539. <span class="gp">... </span> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">value</span> <span class="o">&gt;=</span> <span class="n">other</span><span class="o">.</span><span class="n">value</span>
  1540. <span class="gp">... </span> <span class="k">return</span> <span class="bp">NotImplemented</span>
  1541. <span class="gp">... </span> <span class="k">def</span> <span class="fm">__gt__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">other</span><span class="p">):</span>
  1542. <span class="gp">... </span> <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="vm">__class__</span> <span class="ow">is</span> <span class="n">other</span><span class="o">.</span><span class="vm">__class__</span><span class="p">:</span>
  1543. <span class="gp">... </span> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">value</span> <span class="o">&gt;</span> <span class="n">other</span><span class="o">.</span><span class="n">value</span>
  1544. <span class="gp">... </span> <span class="k">return</span> <span class="bp">NotImplemented</span>
  1545. <span class="gp">... </span> <span class="k">def</span> <span class="fm">__le__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">other</span><span class="p">):</span>
  1546. <span class="gp">... </span> <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="vm">__class__</span> <span class="ow">is</span> <span class="n">other</span><span class="o">.</span><span class="vm">__class__</span><span class="p">:</span>
  1547. <span class="gp">... </span> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">value</span> <span class="o">&lt;=</span> <span class="n">other</span><span class="o">.</span><span class="n">value</span>
  1548. <span class="gp">... </span> <span class="k">return</span> <span class="bp">NotImplemented</span>
  1549. <span class="gp">... </span> <span class="k">def</span> <span class="fm">__lt__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">other</span><span class="p">):</span>
  1550. <span class="gp">... </span> <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="vm">__class__</span> <span class="ow">is</span> <span class="n">other</span><span class="o">.</span><span class="vm">__class__</span><span class="p">:</span>
  1551. <span class="gp">... </span> <span class="k">return</span> <span class="bp">self</span><span class="o">.</span><span class="n">value</span> <span class="o">&lt;</span> <span class="n">other</span><span class="o">.</span><span class="n">value</span>
  1552. <span class="gp">... </span> <span class="k">return</span> <span class="bp">NotImplemented</span>
  1553. <span class="gp">...</span>
  1554. <span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Grade</span><span class="p">(</span><span class="n">OrderedEnum</span><span class="p">):</span>
  1555. <span class="gp">... </span> <span class="n">A</span> <span class="o">=</span> <span class="mi">5</span>
  1556. <span class="gp">... </span> <span class="n">B</span> <span class="o">=</span> <span class="mi">4</span>
  1557. <span class="gp">... </span> <span class="n">C</span> <span class="o">=</span> <span class="mi">3</span>
  1558. <span class="gp">... </span> <span class="n">D</span> <span class="o">=</span> <span class="mi">2</span>
  1559. <span class="gp">... </span> <span class="n">F</span> <span class="o">=</span> <span class="mi">1</span>
  1560. <span class="gp">...</span>
  1561. <span class="gp">&gt;&gt;&gt; </span><span class="n">Grade</span><span class="o">.</span><span class="n">C</span> <span class="o">&lt;</span> <span class="n">Grade</span><span class="o">.</span><span class="n">A</span>
  1562. <span class="go">True</span>
  1563. </pre></div>
  1564. </div>
  1565. </section>
  1566. <section id="duplicatefreeenum">
  1567. <h3>DuplicateFreeEnum<a class="headerlink" href="#duplicatefreeenum" title="Link to this heading">¶</a></h3>
  1568. <p>Raises an error if a duplicate member value is found instead of creating an
  1569. alias:</p>
  1570. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">DuplicateFreeEnum</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  1571. <span class="gp">... </span> <span class="k">def</span> <span class="fm">__init__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="o">*</span><span class="n">args</span><span class="p">):</span>
  1572. <span class="gp">... </span> <span class="bp">cls</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="vm">__class__</span>
  1573. <span class="gp">... </span> <span class="k">if</span> <span class="nb">any</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">value</span> <span class="o">==</span> <span class="n">e</span><span class="o">.</span><span class="n">value</span> <span class="k">for</span> <span class="n">e</span> <span class="ow">in</span> <span class="bp">cls</span><span class="p">):</span>
  1574. <span class="gp">... </span> <span class="n">a</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">name</span>
  1575. <span class="gp">... </span> <span class="n">e</span> <span class="o">=</span> <span class="bp">cls</span><span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">value</span><span class="p">)</span><span class="o">.</span><span class="n">name</span>
  1576. <span class="gp">... </span> <span class="k">raise</span> <span class="ne">ValueError</span><span class="p">(</span>
  1577. <span class="gp">... </span> <span class="s2">&quot;aliases not allowed in DuplicateFreeEnum: </span><span class="si">%r</span><span class="s2"> --&gt; </span><span class="si">%r</span><span class="s2">&quot;</span>
  1578. <span class="gp">... </span> <span class="o">%</span> <span class="p">(</span><span class="n">a</span><span class="p">,</span> <span class="n">e</span><span class="p">))</span>
  1579. <span class="gp">...</span>
  1580. <span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Color</span><span class="p">(</span><span class="n">DuplicateFreeEnum</span><span class="p">):</span>
  1581. <span class="gp">... </span> <span class="n">RED</span> <span class="o">=</span> <span class="mi">1</span>
  1582. <span class="gp">... </span> <span class="n">GREEN</span> <span class="o">=</span> <span class="mi">2</span>
  1583. <span class="gp">... </span> <span class="n">BLUE</span> <span class="o">=</span> <span class="mi">3</span>
  1584. <span class="gp">... </span> <span class="n">GRENE</span> <span class="o">=</span> <span class="mi">2</span>
  1585. <span class="gp">...</span>
  1586. <span class="gt">Traceback (most recent call last):</span>
  1587. <span class="w"> </span><span class="c">...</span>
  1588. <span class="gr">ValueError</span>: <span class="n">aliases not allowed in DuplicateFreeEnum: &#39;GRENE&#39; --&gt; &#39;GREEN&#39;</span>
  1589. </pre></div>
  1590. </div>
  1591. <div class="admonition note">
  1592. <p class="admonition-title">Note</p>
  1593. <p>This is a useful example for subclassing Enum to add or change other
  1594. behaviors as well as disallowing aliases. If the only desired change is
  1595. disallowing aliases, the <a class="reference internal" href="../library/enum.html#enum.unique" title="enum.unique"><code class="xref py py-func docutils literal notranslate"><span class="pre">unique()</span></code></a> decorator can be used instead.</p>
  1596. </div>
  1597. </section>
  1598. <section id="planet">
  1599. <h3>Planet<a class="headerlink" href="#planet" title="Link to this heading">¶</a></h3>
  1600. <p>If <code class="xref py py-meth docutils literal notranslate"><span class="pre">__new__()</span></code> or <code class="xref py py-meth docutils literal notranslate"><span class="pre">__init__()</span></code> is defined, the value of the enum member
  1601. will be passed to those methods:</p>
  1602. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Planet</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
  1603. <span class="gp">... </span> <span class="n">MERCURY</span> <span class="o">=</span> <span class="p">(</span><span class="mf">3.303e+23</span><span class="p">,</span> <span class="mf">2.4397e6</span><span class="p">)</span>
  1604. <span class="gp">... </span> <span class="n">VENUS</span> <span class="o">=</span> <span class="p">(</span><span class="mf">4.869e+24</span><span class="p">,</span> <span class="mf">6.0518e6</span><span class="p">)</span>
  1605. <span class="gp">... </span> <span class="n">EARTH</span> <span class="o">=</span> <span class="p">(</span><span class="mf">5.976e+24</span><span class="p">,</span> <span class="mf">6.37814e6</span><span class="p">)</span>
  1606. <span class="gp">... </span> <span class="n">MARS</span> <span class="o">=</span> <span class="p">(</span><span class="mf">6.421e+23</span><span class="p">,</span> <span class="mf">3.3972e6</span><span class="p">)</span>
  1607. <span class="gp">... </span> <span class="n">JUPITER</span> <span class="o">=</span> <span class="p">(</span><span class="mf">1.9e+27</span><span class="p">,</span> <span class="mf">7.1492e7</span><span class="p">)</span>
  1608. <span class="gp">... </span> <span class="n">SATURN</span> <span class="o">=</span> <span class="p">(</span><span class="mf">5.688e+26</span><span class="p">,</span> <span class="mf">6.0268e7</span><span class="p">)</span>
  1609. <span class="gp">... </span> <span class="n">URANUS</span> <span class="o">=</span> <span class="p">(</span><span class="mf">8.686e+25</span><span class="p">,</span> <span class="mf">2.5559e7</span><span class="p">)</span>
  1610. <span class="gp">... </span> <span class="n">NEPTUNE</span> <span class="o">=</span> <span class="p">(</span><span class="mf">1.024e+26</span><span class="p">,</span> <span class="mf">2.4746e7</span><span class="p">)</span>
  1611. <span class="gp">... </span> <span class="k">def</span> <span class="fm">__init__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">mass</span><span class="p">,</span> <span class="n">radius</span><span class="p">):</span>
  1612. <span class="gp">... </span> <span class="bp">self</span><span class="o">.</span><span class="n">mass</span> <span class="o">=</span> <span class="n">mass</span> <span class="c1"># in kilograms</span>
  1613. <span class="gp">... </span> <span class="bp">self</span><span class="o">.</span><span class="n">radius</span> <span class="o">=</span> <span class="n">radius</span> <span class="c1"># in meters</span>
  1614. <span class="gp">... </span> <span class="nd">@property</span>
  1615. <span class="gp">... </span> <span class="k">def</span> <span class="nf">surface_gravity</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
  1616. <span class="gp">... </span> <span class="c1"># universal gravitational constant (m3 kg-1 s-2)</span>
  1617. <span class="gp">... </span> <span class="n">G</span> <span class="o">=</span> <span class="mf">6.67300E-11</span>
  1618. <span class="gp">... </span> <span class="k">return</span> <span class="n">G</span> <span class="o">*</span> <span class="bp">self</span><span class="o">.</span><span class="n">mass</span> <span class="o">/</span> <span class="p">(</span><span class="bp">self</span><span class="o">.</span><span class="n">radius</span> <span class="o">*</span> <span class="bp">self</span><span class="o">.</span><span class="n">radius</span><span class="p">)</span>
  1619. <span class="gp">...</span>
  1620. <span class="gp">&gt;&gt;&gt; </span><span class="n">Planet</span><span class="o">.</span><span class="n">EARTH</span><span class="o">.</span><span class="n">value</span>
  1621. <span class="go">(5.976e+24, 6378140.0)</span>
  1622. <span class="gp">&gt;&gt;&gt; </span><span class="n">Planet</span><span class="o">.</span><span class="n">EARTH</span><span class="o">.</span><span class="n">surface_gravity</span>
  1623. <span class="go">9.802652743337129</span>
  1624. </pre></div>
  1625. </div>
  1626. </section>
  1627. <section id="timeperiod">
  1628. <span id="enum-time-period"></span><h3>TimePeriod<a class="headerlink" href="#timeperiod" title="Link to this heading">¶</a></h3>
  1629. <p>An example to show the <code class="xref py py-attr docutils literal notranslate"><span class="pre">_ignore_</span></code> attribute in use:</p>
  1630. <div class="highlight-python3 notranslate"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="kn">from</span> <span class="nn">datetime</span> <span class="kn">import</span> <span class="n">timedelta</span>
  1631. <span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Period</span><span class="p">(</span><span class="n">timedelta</span><span class="p">,</span> <span class="n">Enum</span><span class="p">):</span>
  1632. <span class="gp">... </span> <span class="s2">&quot;different lengths of time&quot;</span>
  1633. <span class="gp">... </span> <span class="n">_ignore_</span> <span class="o">=</span> <span class="s1">&#39;Period i&#39;</span>
  1634. <span class="gp">... </span> <span class="n">Period</span> <span class="o">=</span> <span class="nb">vars</span><span class="p">()</span>
  1635. <span class="gp">... </span> <span class="k">for</span> <span class="n">i</span> <span class="ow">in</span> <span class="nb">range</span><span class="p">(</span><span class="mi">367</span><span class="p">):</span>
  1636. <span class="gp">... </span> <span class="n">Period</span><span class="p">[</span><span class="s1">&#39;day_</span><span class="si">%d</span><span class="s1">&#39;</span> <span class="o">%</span> <span class="n">i</span><span class="p">]</span> <span class="o">=</span> <span class="n">i</span>
  1637. <span class="gp">...</span>
  1638. <span class="gp">&gt;&gt;&gt; </span><span class="nb">list</span><span class="p">(</span><span class="n">Period</span><span class="p">)[:</span><span class="mi">2</span><span class="p">]</span>
  1639. <span class="go">[&lt;Period.day_0: datetime.timedelta(0)&gt;, &lt;Period.day_1: datetime.timedelta(days=1)&gt;]</span>
  1640. <span class="gp">&gt;&gt;&gt; </span><span class="nb">list</span><span class="p">(</span><span class="n">Period</span><span class="p">)[</span><span class="o">-</span><span class="mi">2</span><span class="p">:]</span>
  1641. <span class="go">[&lt;Period.day_365: datetime.timedelta(days=365)&gt;, &lt;Period.day_366: datetime.timedelta(days=366)&gt;]</span>
  1642. </pre></div>
  1643. </div>
  1644. </section>
  1645. </section>
  1646. <section id="subclassing-enumtype">
  1647. <span id="enumtype-examples"></span><h2>Subclassing EnumType<a class="headerlink" href="#subclassing-enumtype" title="Link to this heading">¶</a></h2>
  1648. <p>While most enum needs can be met by customizing <a class="reference internal" href="../library/enum.html#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal notranslate"><span class="pre">Enum</span></code></a> subclasses,
  1649. either with class decorators or custom functions, <a class="reference internal" href="../library/enum.html#enum.EnumType" title="enum.EnumType"><code class="xref py py-class docutils literal notranslate"><span class="pre">EnumType</span></code></a> can be
  1650. subclassed to provide a different Enum experience.</p>
  1651. </section>
  1652. </section>
  1653. <div class="clearer"></div>
  1654. </div>
  1655. </div>
  1656. </div>
  1657. <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
  1658. <div class="sphinxsidebarwrapper">
  1659. <div>
  1660. <h3><a href="../contents.html">Table of Contents</a></h3>
  1661. <ul>
  1662. <li><a class="reference internal" href="#">Enum HOWTO</a><ul>
  1663. <li><a class="reference internal" href="#programmatic-access-to-enumeration-members-and-their-attributes">Programmatic access to enumeration members and their attributes</a></li>
  1664. <li><a class="reference internal" href="#duplicating-enum-members-and-values">Duplicating enum members and values</a></li>
  1665. <li><a class="reference internal" href="#ensuring-unique-enumeration-values">Ensuring unique enumeration values</a></li>
  1666. <li><a class="reference internal" href="#using-automatic-values">Using automatic values</a></li>
  1667. <li><a class="reference internal" href="#iteration">Iteration</a></li>
  1668. <li><a class="reference internal" href="#comparisons">Comparisons</a></li>
  1669. <li><a class="reference internal" href="#allowed-members-and-attributes-of-enumerations">Allowed members and attributes of enumerations</a></li>
  1670. <li><a class="reference internal" href="#restricted-enum-subclassing">Restricted Enum subclassing</a></li>
  1671. <li><a class="reference internal" href="#dataclass-support">Dataclass support</a></li>
  1672. <li><a class="reference internal" href="#pickling">Pickling</a></li>
  1673. <li><a class="reference internal" href="#functional-api">Functional API</a></li>
  1674. <li><a class="reference internal" href="#derived-enumerations">Derived Enumerations</a><ul>
  1675. <li><a class="reference internal" href="#intenum">IntEnum</a></li>
  1676. <li><a class="reference internal" href="#strenum">StrEnum</a></li>
  1677. <li><a class="reference internal" href="#intflag">IntFlag</a></li>
  1678. <li><a class="reference internal" href="#flag">Flag</a></li>
  1679. <li><a class="reference internal" href="#others">Others</a></li>
  1680. </ul>
  1681. </li>
  1682. <li><a class="reference internal" href="#when-to-use-new-vs-init">When to use <code class="xref py py-meth docutils literal notranslate"><span class="pre">__new__()</span></code> vs. <code class="xref py py-meth docutils literal notranslate"><span class="pre">__init__()</span></code></a><ul>
  1683. <li><a class="reference internal" href="#finer-points">Finer Points</a><ul>
  1684. <li><a class="reference internal" href="#supported-dunder-names">Supported <code class="docutils literal notranslate"><span class="pre">__dunder__</span></code> names</a></li>
  1685. <li><a class="reference internal" href="#supported-sunder-names">Supported <code class="docutils literal notranslate"><span class="pre">_sunder_</span></code> names</a></li>
  1686. <li><a class="reference internal" href="#private-names">_Private__names</a></li>
  1687. <li><a class="reference internal" href="#enum-member-type"><code class="docutils literal notranslate"><span class="pre">Enum</span></code> member type</a></li>
  1688. <li><a class="reference internal" href="#creating-members-that-are-mixed-with-other-data-types">Creating members that are mixed with other data types</a></li>
  1689. <li><a class="reference internal" href="#boolean-value-of-enum-classes-and-members">Boolean value of <code class="docutils literal notranslate"><span class="pre">Enum</span></code> classes and members</a></li>
  1690. <li><a class="reference internal" href="#enum-classes-with-methods"><code class="docutils literal notranslate"><span class="pre">Enum</span></code> classes with methods</a></li>
  1691. <li><a class="reference internal" href="#combining-members-of-flag">Combining members of <code class="docutils literal notranslate"><span class="pre">Flag</span></code></a></li>
  1692. <li><a class="reference internal" href="#flag-and-intflag-minutia"><code class="docutils literal notranslate"><span class="pre">Flag</span></code> and <code class="docutils literal notranslate"><span class="pre">IntFlag</span></code> minutia</a></li>
  1693. </ul>
  1694. </li>
  1695. </ul>
  1696. </li>
  1697. <li><a class="reference internal" href="#how-are-enums-and-flags-different">How are Enums and Flags different?</a><ul>
  1698. <li><a class="reference internal" href="#enum-classes">Enum Classes</a></li>
  1699. <li><a class="reference internal" href="#flag-classes">Flag Classes</a></li>
  1700. <li><a class="reference internal" href="#enum-members-aka-instances">Enum Members (aka instances)</a></li>
  1701. <li><a class="reference internal" href="#flag-members">Flag Members</a></li>
  1702. </ul>
  1703. </li>
  1704. <li><a class="reference internal" href="#enum-cookbook">Enum Cookbook</a><ul>
  1705. <li><a class="reference internal" href="#omitting-values">Omitting values</a><ul>
  1706. <li><a class="reference internal" href="#using-auto">Using <code class="xref py py-class docutils literal notranslate"><span class="pre">auto</span></code></a></li>
  1707. <li><a class="reference internal" href="#using-object">Using <code class="xref py py-class docutils literal notranslate"><span class="pre">object</span></code></a></li>
  1708. <li><a class="reference internal" href="#using-a-descriptive-string">Using a descriptive string</a></li>
  1709. <li><a class="reference internal" href="#using-a-custom-new">Using a custom <code class="xref py py-meth docutils literal notranslate"><span class="pre">__new__()</span></code></a></li>
  1710. </ul>
  1711. </li>
  1712. <li><a class="reference internal" href="#orderedenum">OrderedEnum</a></li>
  1713. <li><a class="reference internal" href="#duplicatefreeenum">DuplicateFreeEnum</a></li>
  1714. <li><a class="reference internal" href="#planet">Planet</a></li>
  1715. <li><a class="reference internal" href="#timeperiod">TimePeriod</a></li>
  1716. </ul>
  1717. </li>
  1718. <li><a class="reference internal" href="#subclassing-enumtype">Subclassing EnumType</a></li>
  1719. </ul>
  1720. </li>
  1721. </ul>
  1722. </div>
  1723. <div>
  1724. <h4>Previous topic</h4>
  1725. <p class="topless"><a href="gdb_helpers.html"
  1726. title="previous chapter">Debugging C API extensions and CPython Internals with GDB</a></p>
  1727. </div>
  1728. <div>
  1729. <h4>Next topic</h4>
  1730. <p class="topless"><a href="functional.html"
  1731. title="next chapter">Functional Programming HOWTO</a></p>
  1732. </div>
  1733. <div role="note" aria-label="source link">
  1734. <h3>This Page</h3>
  1735. <ul class="this-page-menu">
  1736. <li><a href="../bugs.html">Report a Bug</a></li>
  1737. <li>
  1738. <a href="https://github.com/python/cpython/blob/main/Doc/howto/enum.rst"
  1739. rel="nofollow">Show Source
  1740. </a>
  1741. </li>
  1742. </ul>
  1743. </div>
  1744. </div>
  1745. <div id="sidebarbutton" title="Collapse sidebar">
  1746. <span>«</span>
  1747. </div>
  1748. </div>
  1749. <div class="clearer"></div>
  1750. </div>
  1751. <div class="related" role="navigation" aria-label="related navigation">
  1752. <h3>Navigation</h3>
  1753. <ul>
  1754. <li class="right" style="margin-right: 10px">
  1755. <a href="../genindex.html" title="General Index"
  1756. >index</a></li>
  1757. <li class="right" >
  1758. <a href="../py-modindex.html" title="Python Module Index"
  1759. >modules</a> |</li>
  1760. <li class="right" >
  1761. <a href="functional.html" title="Functional Programming HOWTO"
  1762. >next</a> |</li>
  1763. <li class="right" >
  1764. <a href="gdb_helpers.html" title="Debugging C API extensions and CPython Internals with GDB"
  1765. >previous</a> |</li>
  1766. <li><img src="../_static/py.svg" alt="Python logo" style="vertical-align: middle; margin-top: -1px"/></li>
  1767. <li><a href="https://www.python.org/">Python</a> &#187;</li>
  1768. <li class="switchers">
  1769. <div class="language_switcher_placeholder"></div>
  1770. <div class="version_switcher_placeholder"></div>
  1771. </li>
  1772. <li>
  1773. </li>
  1774. <li id="cpython-language-and-version">
  1775. <a href="../index.html">3.12.3 Documentation</a> &#187;
  1776. </li>
  1777. <li class="nav-item nav-item-1"><a href="index.html" >Python HOWTOs</a> &#187;</li>
  1778. <li class="nav-item nav-item-this"><a href="">Enum HOWTO</a></li>
  1779. <li class="right">
  1780. <div class="inline-search" role="search">
  1781. <form class="inline-search" action="../search.html" method="get">
  1782. <input placeholder="Quick search" aria-label="Quick search" type="search" name="q" id="search-box" />
  1783. <input type="submit" value="Go" />
  1784. </form>
  1785. </div>
  1786. |
  1787. </li>
  1788. <li class="right">
  1789. <label class="theme-selector-label">
  1790. Theme
  1791. <select class="theme-selector" oninput="activateTheme(this.value)">
  1792. <option value="auto" selected>Auto</option>
  1793. <option value="light">Light</option>
  1794. <option value="dark">Dark</option>
  1795. </select>
  1796. </label> |</li>
  1797. </ul>
  1798. </div>
  1799. <div class="footer">
  1800. &copy;
  1801. <a href="../copyright.html">
  1802. Copyright
  1803. </a>
  1804. 2001-2024, Python Software Foundation.
  1805. <br />
  1806. This page is licensed under the Python Software Foundation License Version 2.
  1807. <br />
  1808. Examples, recipes, and other code in the documentation are additionally licensed under the Zero Clause BSD License.
  1809. <br />
  1810. See <a href="/license.html">History and License</a> for more information.<br />
  1811. <br />
  1812. The Python Software Foundation is a non-profit corporation.
  1813. <a href="https://www.python.org/psf/donations/">Please donate.</a>
  1814. <br />
  1815. <br />
  1816. Last updated on Apr 09, 2024 (13:47 UTC).
  1817. <a href="/bugs.html">Found a bug</a>?
  1818. <br />
  1819. Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 7.2.6.
  1820. </div>
  1821. </body>
  1822. </html>
上海开阖软件有限公司 沪ICP备12045867号-1