~dkuhlman/python-training-materials/Materials

« back to all changes in this revision

Viewing changes to python-3.5.2-docs-html/library/enum.html

  • Committer: Dave Kuhlman
  • Date: 2017-04-15 16:24:56 UTC
  • Revision ID: dkuhlman@davekuhlman.org-20170415162456-iav9vozzg4iwqwv3
Updated docs

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
 
2
  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 
3
 
 
4
 
 
5
<html xmlns="http://www.w3.org/1999/xhtml">
 
6
  <head>
 
7
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 
8
    
 
9
    <title>8.13. enum — Support for enumerations &mdash; Python 3.5.2 documentation</title>
 
10
    
 
11
    <link rel="stylesheet" href="../_static/pydoctheme.css" type="text/css" />
 
12
    <link rel="stylesheet" href="../_static/pygments.css" type="text/css" />
 
13
    
 
14
    <script type="text/javascript">
 
15
      var DOCUMENTATION_OPTIONS = {
 
16
        URL_ROOT:    '../',
 
17
        VERSION:     '3.5.2',
 
18
        COLLAPSE_INDEX: false,
 
19
        FILE_SUFFIX: '.html',
 
20
        HAS_SOURCE:  true
 
21
      };
 
22
    </script>
 
23
    <script type="text/javascript" src="../_static/jquery.js"></script>
 
24
    <script type="text/javascript" src="../_static/underscore.js"></script>
 
25
    <script type="text/javascript" src="../_static/doctools.js"></script>
 
26
    <script type="text/javascript" src="../_static/sidebar.js"></script>
 
27
    <link rel="search" type="application/opensearchdescription+xml"
 
28
          title="Search within Python 3.5.2 documentation"
 
29
          href="../_static/opensearch.xml"/>
 
30
    <link rel="author" title="About these documents" href="../about.html" />
 
31
    <link rel="copyright" title="Copyright" href="../copyright.html" />
 
32
    <link rel="top" title="Python 3.5.2 documentation" href="../contents.html" />
 
33
    <link rel="up" title="8. Data Types" href="datatypes.html" />
 
34
    <link rel="next" title="9. Numeric and Mathematical Modules" href="numeric.html" />
 
35
    <link rel="prev" title="8.12. reprlib — Alternate repr() implementation" href="reprlib.html" />
 
36
    <link rel="shortcut icon" type="image/png" href="../_static/py.png" />
 
37
    
 
38
    <script type="text/javascript" src="../_static/copybutton.js"></script>
 
39
    <script type="text/javascript" src="../_static/version_switch.js"></script>
 
40
    
 
41
    
 
42
 
 
43
 
 
44
  </head>
 
45
  <body role="document">  
 
46
    <div class="related" role="navigation" aria-label="related navigation">
 
47
      <h3>Navigation</h3>
 
48
      <ul>
 
49
        <li class="right" style="margin-right: 10px">
 
50
          <a href="../genindex.html" title="General Index"
 
51
             accesskey="I">index</a></li>
 
52
        <li class="right" >
 
53
          <a href="../py-modindex.html" title="Python Module Index"
 
54
             >modules</a> |</li>
 
55
        <li class="right" >
 
56
          <a href="numeric.html" title="9. Numeric and Mathematical Modules"
 
57
             accesskey="N">next</a> |</li>
 
58
        <li class="right" >
 
59
          <a href="reprlib.html" title="8.12. reprlib — Alternate repr() implementation"
 
60
             accesskey="P">previous</a> |</li>
 
61
        <li><img src="../_static/py.png" alt=""
 
62
                 style="vertical-align: middle; margin-top: -1px"/></li>
 
63
        <li><a href="https://www.python.org/">Python</a> &raquo;</li>
 
64
        <li>
 
65
          <span class="version_switcher_placeholder">3.5.2</span>
 
66
          <a href="../index.html">Documentation </a> &raquo;
 
67
        </li>
 
68
 
 
69
          <li class="nav-item nav-item-1"><a href="index.html" >The Python Standard Library</a> &raquo;</li>
 
70
          <li class="nav-item nav-item-2"><a href="datatypes.html" accesskey="U">8. Data Types</a> &raquo;</li>
 
71
    <li class="right">
 
72
        
 
73
 
 
74
    <div class="inline-search" style="display: none" role="search">
 
75
        <form class="inline-search" action="../search.html" method="get">
 
76
          <input placeholder="Quick search" type="text" name="q" />
 
77
          <input type="submit" value="Go" />
 
78
          <input type="hidden" name="check_keywords" value="yes" />
 
79
          <input type="hidden" name="area" value="default" />
 
80
        </form>
 
81
    </div>
 
82
    <script type="text/javascript">$('.inline-search').show(0);</script>
 
83
         |
 
84
    </li>
 
85
 
 
86
      </ul>
 
87
    </div>    
 
88
 
 
89
    <div class="document">
 
90
      <div class="documentwrapper">
 
91
        <div class="bodywrapper">
 
92
          <div class="body" role="main">
 
93
            
 
94
  <div class="section" id="module-enum">
 
95
<span id="enum-support-for-enumerations"></span><h1>8.13. <a class="reference internal" href="#module-enum" title="enum: Implementation of an enumeration class."><code class="xref py py-mod docutils literal"><span class="pre">enum</span></code></a> &#8212; Support for enumerations<a class="headerlink" href="#module-enum" title="Permalink to this headline">¶</a></h1>
 
96
<div class="versionadded">
 
97
<p><span class="versionmodified">New in version 3.4.</span></p>
 
98
</div>
 
99
<p><strong>Source code:</strong> <a class="reference external" href="https://hg.python.org/cpython/file/3.5/Lib/enum.py">Lib/enum.py</a></p>
 
100
<hr class="docutils" />
 
101
<p>An enumeration is a set of symbolic names (members) bound to unique,
 
102
constant values.  Within an enumeration, the members can be compared
 
103
by identity, and the enumeration itself can be iterated over.</p>
 
104
<div class="section" id="module-contents">
 
105
<h2>8.13.1. Module Contents<a class="headerlink" href="#module-contents" title="Permalink to this headline">¶</a></h2>
 
106
<p>This module defines two enumeration classes that can be used to define unique
 
107
sets of names and values: <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> and <a class="reference internal" href="#enum.IntEnum" title="enum.IntEnum"><code class="xref py py-class docutils literal"><span class="pre">IntEnum</span></code></a>.  It also defines
 
108
one decorator, <a class="reference internal" href="#enum.unique" title="enum.unique"><code class="xref py py-func docutils literal"><span class="pre">unique()</span></code></a>.</p>
 
109
<dl class="class">
 
110
<dt id="enum.Enum">
 
111
<em class="property">class </em><code class="descclassname">enum.</code><code class="descname">Enum</code><a class="headerlink" href="#enum.Enum" title="Permalink to this definition">¶</a></dt>
 
112
<dd><p>Base class for creating enumerated constants.  See section
 
113
<a class="reference internal" href="#functional-api">Functional API</a> for an alternate construction syntax.</p>
 
114
</dd></dl>
 
115
 
 
116
<dl class="class">
 
117
<dt id="enum.IntEnum">
 
118
<em class="property">class </em><code class="descclassname">enum.</code><code class="descname">IntEnum</code><a class="headerlink" href="#enum.IntEnum" title="Permalink to this definition">¶</a></dt>
 
119
<dd><p>Base class for creating enumerated constants that are also
 
120
subclasses of <a class="reference internal" href="functions.html#int" title="int"><code class="xref py py-class docutils literal"><span class="pre">int</span></code></a>.</p>
 
121
</dd></dl>
 
122
 
 
123
<dl class="function">
 
124
<dt id="enum.unique">
 
125
<code class="descclassname">enum.</code><code class="descname">unique</code><span class="sig-paren">(</span><span class="sig-paren">)</span><a class="headerlink" href="#enum.unique" title="Permalink to this definition">¶</a></dt>
 
126
<dd><p>Enum class decorator that ensures only one name is bound to any one value.</p>
 
127
</dd></dl>
 
128
 
 
129
</div>
 
130
<div class="section" id="creating-an-enum">
 
131
<h2>8.13.2. Creating an Enum<a class="headerlink" href="#creating-an-enum" title="Permalink to this headline">¶</a></h2>
 
132
<p>Enumerations are created using the <a class="reference internal" href="../reference/compound_stmts.html#class"><code class="xref std std-keyword docutils literal"><span class="pre">class</span></code></a> syntax, which makes them
 
133
easy to read and write.  An alternative creation method is described in
 
134
<a class="reference internal" href="#functional-api">Functional API</a>.  To define an enumeration, subclass <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> as
 
135
follows:</p>
 
136
<div class="highlight-python3"><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="k">import</span> <span class="n">Enum</span>
 
137
<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>
 
138
<span class="gp">... </span>    <span class="n">red</span> <span class="o">=</span> <span class="mi">1</span>
 
139
<span class="gp">... </span>    <span class="n">green</span> <span class="o">=</span> <span class="mi">2</span>
 
140
<span class="gp">... </span>    <span class="n">blue</span> <span class="o">=</span> <span class="mi">3</span>
 
141
<span class="gp">...</span>
 
142
</pre></div>
 
143
</div>
 
144
<div class="admonition note">
 
145
<p class="first admonition-title">Note</p>
 
146
<p>Nomenclature</p>
 
147
<ul class="last simple">
 
148
<li>The class <code class="xref py py-class docutils literal"><span class="pre">Color</span></code> is an <em>enumeration</em> (or <em>enum</em>)</li>
 
149
<li>The attributes <code class="xref py py-attr docutils literal"><span class="pre">Color.red</span></code>, <code class="xref py py-attr docutils literal"><span class="pre">Color.green</span></code>, etc., are
 
150
<em>enumeration members</em> (or <em>enum members</em>).</li>
 
151
<li>The enum members have <em>names</em> and <em>values</em> (the name of
 
152
<code class="xref py py-attr docutils literal"><span class="pre">Color.red</span></code> is <code class="docutils literal"><span class="pre">red</span></code>, the value of <code class="xref py py-attr docutils literal"><span class="pre">Color.blue</span></code> is
 
153
<code class="docutils literal"><span class="pre">3</span></code>, etc.)</li>
 
154
</ul>
 
155
</div>
 
156
<div class="admonition note">
 
157
<p class="first admonition-title">Note</p>
 
158
<p class="last">Even though we use the <a class="reference internal" href="../reference/compound_stmts.html#class"><code class="xref std std-keyword docutils literal"><span class="pre">class</span></code></a> syntax to create Enums, Enums
 
159
are not normal Python classes.  See <a class="reference internal" href="#how-are-enums-different">How are Enums different?</a> for
 
160
more details.</p>
 
161
</div>
 
162
<p>Enumeration members have human readable string representations:</p>
 
163
<div class="highlight-python3"><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">Color</span><span class="o">.</span><span class="n">red</span><span class="p">)</span>
 
164
<span class="go">Color.red</span>
 
165
</pre></div>
 
166
</div>
 
167
<p>...while their <code class="docutils literal"><span class="pre">repr</span></code> has more information:</p>
 
168
<div class="highlight-python3"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="nb">print</span><span class="p">(</span><span class="nb">repr</span><span class="p">(</span><span class="n">Color</span><span class="o">.</span><span class="n">red</span><span class="p">))</span>
 
169
<span class="go">&lt;Color.red: 1&gt;</span>
 
170
</pre></div>
 
171
</div>
 
172
<p>The <em>type</em> of an enumeration member is the enumeration it belongs to:</p>
 
173
<div class="highlight-python3"><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">Color</span><span class="o">.</span><span class="n">red</span><span class="p">)</span>
 
174
<span class="go">&lt;enum &#39;Color&#39;&gt;</span>
 
175
<span class="gp">&gt;&gt;&gt; </span><span class="nb">isinstance</span><span class="p">(</span><span class="n">Color</span><span class="o">.</span><span class="n">green</span><span class="p">,</span> <span class="n">Color</span><span class="p">)</span>
 
176
<span class="go">True</span>
 
177
<span class="go">&gt;&gt;&gt;</span>
 
178
</pre></div>
 
179
</div>
 
180
<p>Enum members also have a property that contains just their item name:</p>
 
181
<div class="highlight-python3"><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">Color</span><span class="o">.</span><span class="n">red</span><span class="o">.</span><span class="n">name</span><span class="p">)</span>
 
182
<span class="go">red</span>
 
183
</pre></div>
 
184
</div>
 
185
<p>Enumerations support iteration, in definition order:</p>
 
186
<div class="highlight-python3"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">Shake</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
 
187
<span class="gp">... </span>    <span class="n">vanilla</span> <span class="o">=</span> <span class="mi">7</span>
 
188
<span class="gp">... </span>    <span class="n">chocolate</span> <span class="o">=</span> <span class="mi">4</span>
 
189
<span class="gp">... </span>    <span class="n">cookies</span> <span class="o">=</span> <span class="mi">9</span>
 
190
<span class="gp">... </span>    <span class="n">mint</span> <span class="o">=</span> <span class="mi">3</span>
 
191
<span class="gp">...</span>
 
192
<span class="gp">&gt;&gt;&gt; </span><span class="k">for</span> <span class="n">shake</span> <span class="ow">in</span> <span class="n">Shake</span><span class="p">:</span>
 
193
<span class="gp">... </span>    <span class="nb">print</span><span class="p">(</span><span class="n">shake</span><span class="p">)</span>
 
194
<span class="gp">...</span>
 
195
<span class="go">Shake.vanilla</span>
 
196
<span class="go">Shake.chocolate</span>
 
197
<span class="go">Shake.cookies</span>
 
198
<span class="go">Shake.mint</span>
 
199
</pre></div>
 
200
</div>
 
201
<p>Enumeration members are hashable, so they can be used in dictionaries and sets:</p>
 
202
<div class="highlight-python3"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="n">apples</span> <span class="o">=</span> <span class="p">{}</span>
 
203
<span class="gp">&gt;&gt;&gt; </span><span class="n">apples</span><span class="p">[</span><span class="n">Color</span><span class="o">.</span><span class="n">red</span><span class="p">]</span> <span class="o">=</span> <span class="s1">&#39;red delicious&#39;</span>
 
204
<span class="gp">&gt;&gt;&gt; </span><span class="n">apples</span><span class="p">[</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="s1">&#39;granny smith&#39;</span>
 
205
<span class="gp">&gt;&gt;&gt; </span><span class="n">apples</span> <span class="o">==</span> <span class="p">{</span><span class="n">Color</span><span class="o">.</span><span class="n">red</span><span class="p">:</span> <span class="s1">&#39;red delicious&#39;</span><span class="p">,</span> <span class="n">Color</span><span class="o">.</span><span class="n">green</span><span class="p">:</span> <span class="s1">&#39;granny smith&#39;</span><span class="p">}</span>
 
206
<span class="go">True</span>
 
207
</pre></div>
 
208
</div>
 
209
</div>
 
210
<div class="section" id="programmatic-access-to-enumeration-members-and-their-attributes">
 
211
<h2>8.13.3. Programmatic access to enumeration members and their attributes<a class="headerlink" href="#programmatic-access-to-enumeration-members-and-their-attributes" title="Permalink to this headline">¶</a></h2>
 
212
<p>Sometimes it&#8217;s useful to access members in enumerations programmatically (i.e.
 
213
situations where <code class="docutils literal"><span class="pre">Color.red</span></code> won&#8217;t do because the exact color is not known
 
214
at program-writing time).  <code class="docutils literal"><span class="pre">Enum</span></code> allows such access:</p>
 
215
<div class="highlight-python3"><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>
 
216
<span class="go">&lt;Color.red: 1&gt;</span>
 
217
<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>
 
218
<span class="go">&lt;Color.blue: 3&gt;</span>
 
219
</pre></div>
 
220
</div>
 
221
<p>If you want to access enum members by <em>name</em>, use item access:</p>
 
222
<div class="highlight-python3"><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>
 
223
<span class="go">&lt;Color.red: 1&gt;</span>
 
224
<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>
 
225
<span class="go">&lt;Color.green: 2&gt;</span>
 
226
</pre></div>
 
227
</div>
 
228
<p>If you have an enum member and need its <code class="xref py py-attr docutils literal"><span class="pre">name</span></code> or <code class="xref py py-attr docutils literal"><span class="pre">value</span></code>:</p>
 
229
<div class="highlight-python3"><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>
 
230
<span class="gp">&gt;&gt;&gt; </span><span class="n">member</span><span class="o">.</span><span class="n">name</span>
 
231
<span class="go">&#39;red&#39;</span>
 
232
<span class="gp">&gt;&gt;&gt; </span><span class="n">member</span><span class="o">.</span><span class="n">value</span>
 
233
<span class="go">1</span>
 
234
</pre></div>
 
235
</div>
 
236
</div>
 
237
<div class="section" id="duplicating-enum-members-and-values">
 
238
<h2>8.13.4. Duplicating enum members and values<a class="headerlink" href="#duplicating-enum-members-and-values" title="Permalink to this headline">¶</a></h2>
 
239
<p>Having two enum members with the same name is invalid:</p>
 
240
<div class="highlight-python3"><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>
 
241
<span class="gp">... </span>    <span class="n">square</span> <span class="o">=</span> <span class="mi">2</span>
 
242
<span class="gp">... </span>    <span class="n">square</span> <span class="o">=</span> <span class="mi">3</span>
 
243
<span class="gp">...</span>
 
244
<span class="gt">Traceback (most recent call last):</span>
 
245
<span class="c">...</span>
 
246
<span class="gr">TypeError</span>: <span class="n">Attempted to reuse key: &#39;square&#39;</span>
 
247
</pre></div>
 
248
</div>
 
249
<p>However, two enum members are allowed to have the same value.  Given two members
 
250
A and B with the same value (and A defined first), B is an alias to A.  By-value
 
251
lookup of the value of A and B will return A.  By-name lookup of B will also
 
252
return A:</p>
 
253
<div class="highlight-python3"><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>
 
254
<span class="gp">... </span>    <span class="n">square</span> <span class="o">=</span> <span class="mi">2</span>
 
255
<span class="gp">... </span>    <span class="n">diamond</span> <span class="o">=</span> <span class="mi">1</span>
 
256
<span class="gp">... </span>    <span class="n">circle</span> <span class="o">=</span> <span class="mi">3</span>
 
257
<span class="gp">... </span>    <span class="n">alias_for_square</span> <span class="o">=</span> <span class="mi">2</span>
 
258
<span class="gp">...</span>
 
259
<span class="gp">&gt;&gt;&gt; </span><span class="n">Shape</span><span class="o">.</span><span class="n">square</span>
 
260
<span class="go">&lt;Shape.square: 2&gt;</span>
 
261
<span class="gp">&gt;&gt;&gt; </span><span class="n">Shape</span><span class="o">.</span><span class="n">alias_for_square</span>
 
262
<span class="go">&lt;Shape.square: 2&gt;</span>
 
263
<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>
 
264
<span class="go">&lt;Shape.square: 2&gt;</span>
 
265
</pre></div>
 
266
</div>
 
267
<div class="admonition note">
 
268
<p class="first admonition-title">Note</p>
 
269
<p class="last">Attempting to create a member with the same name as an already
 
270
defined attribute (another member, a method, etc.) or attempting to create
 
271
an attribute with the same name as a member is not allowed.</p>
 
272
</div>
 
273
</div>
 
274
<div class="section" id="ensuring-unique-enumeration-values">
 
275
<h2>8.13.5. Ensuring unique enumeration values<a class="headerlink" href="#ensuring-unique-enumeration-values" title="Permalink to this headline">¶</a></h2>
 
276
<p>By default, enumerations allow multiple names as aliases for the same value.
 
277
When this behavior isn&#8217;t desired, the following decorator can be used to
 
278
ensure each value is used only once in the enumeration:</p>
 
279
<dl class="function">
 
280
<dt>
 
281
<code class="descclassname">&#64;</code><code class="descclassname">enum.</code><code class="descname">unique</code></dt>
 
282
<dd></dd></dl>
 
283
 
 
284
<p>A <a class="reference internal" href="../reference/compound_stmts.html#class"><code class="xref std std-keyword docutils literal"><span class="pre">class</span></code></a> decorator specifically for enumerations.  It searches an
 
285
enumeration&#8217;s <code class="xref py py-attr docutils literal"><span class="pre">__members__</span></code> gathering any aliases it finds; if any are
 
286
found <a class="reference internal" href="exceptions.html#ValueError" title="ValueError"><code class="xref py py-exc docutils literal"><span class="pre">ValueError</span></code></a> is raised with the details:</p>
 
287
<div class="highlight-python3"><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="k">import</span> <span class="n">Enum</span><span class="p">,</span> <span class="n">unique</span>
 
288
<span class="gp">&gt;&gt;&gt; </span><span class="nd">@unique</span>
 
289
<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>
 
290
<span class="gp">... </span>    <span class="n">one</span> <span class="o">=</span> <span class="mi">1</span>
 
291
<span class="gp">... </span>    <span class="n">two</span> <span class="o">=</span> <span class="mi">2</span>
 
292
<span class="gp">... </span>    <span class="n">three</span> <span class="o">=</span> <span class="mi">3</span>
 
293
<span class="gp">... </span>    <span class="n">four</span> <span class="o">=</span> <span class="mi">3</span>
 
294
<span class="gp">...</span>
 
295
<span class="gt">Traceback (most recent call last):</span>
 
296
<span class="c">...</span>
 
297
<span class="gr">ValueError</span>: <span class="n">duplicate values found in &lt;enum &#39;Mistake&#39;&gt;: four -&gt; three</span>
 
298
</pre></div>
 
299
</div>
 
300
</div>
 
301
<div class="section" id="iteration">
 
302
<h2>8.13.6. Iteration<a class="headerlink" href="#iteration" title="Permalink to this headline">¶</a></h2>
 
303
<p>Iterating over the members of an enum does not provide the aliases:</p>
 
304
<div class="highlight-python3"><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>
 
305
<span class="go">[&lt;Shape.square: 2&gt;, &lt;Shape.diamond: 1&gt;, &lt;Shape.circle: 3&gt;]</span>
 
306
</pre></div>
 
307
</div>
 
308
<p>The special attribute <code class="docutils literal"><span class="pre">__members__</span></code> is an ordered dictionary mapping names
 
309
to members.  It includes all names defined in the enumeration, including the
 
310
aliases:</p>
 
311
<div class="highlight-python3"><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>
 
312
<span class="gp">... </span>    <span class="n">name</span><span class="p">,</span> <span class="n">member</span>
 
313
<span class="gp">...</span>
 
314
<span class="go">(&#39;square&#39;, &lt;Shape.square: 2&gt;)</span>
 
315
<span class="go">(&#39;diamond&#39;, &lt;Shape.diamond: 1&gt;)</span>
 
316
<span class="go">(&#39;circle&#39;, &lt;Shape.circle: 3&gt;)</span>
 
317
<span class="go">(&#39;alias_for_square&#39;, &lt;Shape.square: 2&gt;)</span>
 
318
</pre></div>
 
319
</div>
 
320
<p>The <code class="docutils literal"><span class="pre">__members__</span></code> attribute can be used for detailed programmatic access to
 
321
the enumeration members.  For example, finding all the aliases:</p>
 
322
<div class="highlight-python3"><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>
 
323
<span class="go">[&#39;alias_for_square&#39;]</span>
 
324
</pre></div>
 
325
</div>
 
326
</div>
 
327
<div class="section" id="comparisons">
 
328
<h2>8.13.7. Comparisons<a class="headerlink" href="#comparisons" title="Permalink to this headline">¶</a></h2>
 
329
<p>Enumeration members are compared by identity:</p>
 
330
<div class="highlight-python3"><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>
 
331
<span class="go">True</span>
 
332
<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>
 
333
<span class="go">False</span>
 
334
<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>
 
335
<span class="go">True</span>
 
336
</pre></div>
 
337
</div>
 
338
<p>Ordered comparisons between enumeration values are <em>not</em> supported.  Enum
 
339
members are not integers (but see <a class="reference internal" href="#intenum">IntEnum</a> below):</p>
 
340
<div class="highlight-python3"><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>
 
341
<span class="gt">Traceback (most recent call last):</span>
 
342
  File <span class="nb">&quot;&lt;stdin&gt;&quot;</span>, line <span class="m">1</span>, in <span class="n">&lt;module&gt;</span>
 
343
<span class="gr">TypeError</span>: <span class="n">unorderable types: Color() &lt; Color()</span>
 
344
</pre></div>
 
345
</div>
 
346
<p>Equality comparisons are defined though:</p>
 
347
<div class="highlight-python3"><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>
 
348
<span class="go">False</span>
 
349
<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>
 
350
<span class="go">True</span>
 
351
<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>
 
352
<span class="go">True</span>
 
353
</pre></div>
 
354
</div>
 
355
<p>Comparisons against non-enumeration values will always compare not equal
 
356
(again, <a class="reference internal" href="#enum.IntEnum" title="enum.IntEnum"><code class="xref py py-class docutils literal"><span class="pre">IntEnum</span></code></a> was explicitly designed to behave differently, see
 
357
below):</p>
 
358
<div class="highlight-python3"><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>
 
359
<span class="go">False</span>
 
360
</pre></div>
 
361
</div>
 
362
</div>
 
363
<div class="section" id="allowed-members-and-attributes-of-enumerations">
 
364
<h2>8.13.8. Allowed members and attributes of enumerations<a class="headerlink" href="#allowed-members-and-attributes-of-enumerations" title="Permalink to this headline">¶</a></h2>
 
365
<p>The examples above use integers for enumeration values.  Using integers is
 
366
short and handy (and provided by default by the <a class="reference internal" href="#functional-api">Functional API</a>), but not
 
367
strictly enforced.  In the vast majority of use-cases, one doesn&#8217;t care what
 
368
the actual value of an enumeration is.  But if the value <em>is</em> important,
 
369
enumerations can have arbitrary values.</p>
 
370
<p>Enumerations are Python classes, and can have methods and special methods as
 
371
usual.  If we have this enumeration:</p>
 
372
<div class="highlight-python3"><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>
 
373
<span class="gp">... </span>    <span class="n">funky</span> <span class="o">=</span> <span class="mi">1</span>
 
374
<span class="gp">... </span>    <span class="n">happy</span> <span class="o">=</span> <span class="mi">3</span>
 
375
<span class="gp">...</span>
 
376
<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>
 
377
<span class="gp">... </span>        <span class="c1"># self is the member here</span>
 
378
<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>
 
379
<span class="gp">...</span>
 
380
<span class="gp">... </span>    <span class="k">def</span> <span class="nf">__str__</span><span class="p">(</span><span class="bp">self</span><span class="p">):</span>
 
381
<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>
 
382
<span class="gp">...</span>
 
383
<span class="gp">... </span>    <span class="nd">@classmethod</span>
 
384
<span class="gp">... </span>    <span class="k">def</span> <span class="nf">favorite_mood</span><span class="p">(</span><span class="n">cls</span><span class="p">):</span>
 
385
<span class="gp">... </span>        <span class="c1"># cls here is the enumeration</span>
 
386
<span class="gp">... </span>        <span class="k">return</span> <span class="n">cls</span><span class="o">.</span><span class="n">happy</span>
 
387
<span class="gp">...</span>
 
388
</pre></div>
 
389
</div>
 
390
<p>Then:</p>
 
391
<div class="highlight-python3"><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>
 
392
<span class="go">&lt;Mood.happy: 3&gt;</span>
 
393
<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>
 
394
<span class="go">(&#39;happy&#39;, 3)</span>
 
395
<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>
 
396
<span class="go">&#39;my custom str! 1&#39;</span>
 
397
</pre></div>
 
398
</div>
 
399
<p>The rules for what is allowed are as follows: names that start and end with
 
400
a single underscore are reserved by enum and cannot be used; all other
 
401
attributes defined within an enumeration will become members of this
 
402
enumeration, with the exception of special methods (<a class="reference internal" href="../reference/datamodel.html#object.__str__" title="object.__str__"><code class="xref py py-meth docutils literal"><span class="pre">__str__()</span></code></a>,
 
403
<a class="reference internal" href="../reference/datamodel.html#object.__add__" title="object.__add__"><code class="xref py py-meth docutils literal"><span class="pre">__add__()</span></code></a>, etc.) and descriptors (methods are also descriptors).</p>
 
404
<p>Note:  if your enumeration defines <a class="reference internal" href="../reference/datamodel.html#object.__new__" title="object.__new__"><code class="xref py py-meth docutils literal"><span class="pre">__new__()</span></code></a> and/or <a class="reference internal" href="../reference/datamodel.html#object.__init__" title="object.__init__"><code class="xref py py-meth docutils literal"><span class="pre">__init__()</span></code></a> then
 
405
whatever value(s) were given to the enum member will be passed into those
 
406
methods.  See <a class="reference internal" href="#planet">Planet</a> for an example.</p>
 
407
</div>
 
408
<div class="section" id="restricted-subclassing-of-enumerations">
 
409
<h2>8.13.9. Restricted subclassing of enumerations<a class="headerlink" href="#restricted-subclassing-of-enumerations" title="Permalink to this headline">¶</a></h2>
 
410
<p>Subclassing an enumeration is allowed only if the enumeration does not define
 
411
any members.  So this is forbidden:</p>
 
412
<div class="highlight-python3"><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>
 
413
<span class="gp">... </span>    <span class="n">pink</span> <span class="o">=</span> <span class="mi">17</span>
 
414
<span class="gp">...</span>
 
415
<span class="gt">Traceback (most recent call last):</span>
 
416
<span class="c">...</span>
 
417
<span class="gr">TypeError</span>: <span class="n">Cannot extend enumerations</span>
 
418
</pre></div>
 
419
</div>
 
420
<p>But this is allowed:</p>
 
421
<div class="highlight-python3"><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>
 
422
<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>
 
423
<span class="gp">... </span>        <span class="k">pass</span>
 
424
<span class="gp">...</span>
 
425
<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>
 
426
<span class="gp">... </span>    <span class="n">happy</span> <span class="o">=</span> <span class="mi">1</span>
 
427
<span class="gp">... </span>    <span class="n">sad</span> <span class="o">=</span> <span class="mi">2</span>
 
428
<span class="gp">...</span>
 
429
</pre></div>
 
430
</div>
 
431
<p>Allowing subclassing of enums that define members would lead to a violation of
 
432
some important invariants of types and instances.  On the other hand, it makes
 
433
sense to allow sharing some common behavior between a group of enumerations.
 
434
(See <a class="reference internal" href="#orderedenum">OrderedEnum</a> for an example.)</p>
 
435
</div>
 
436
<div class="section" id="pickling">
 
437
<h2>8.13.10. Pickling<a class="headerlink" href="#pickling" title="Permalink to this headline">¶</a></h2>
 
438
<p>Enumerations can be pickled and unpickled:</p>
 
439
<div class="highlight-python3"><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="k">import</span> <span class="n">Fruit</span>
 
440
<span class="gp">&gt;&gt;&gt; </span><span class="kn">from</span> <span class="nn">pickle</span> <span class="k">import</span> <span class="n">dumps</span><span class="p">,</span> <span class="n">loads</span>
 
441
<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>
 
442
<span class="go">True</span>
 
443
</pre></div>
 
444
</div>
 
445
<p>The usual restrictions for pickling apply: picklable enums must be defined in
 
446
the top level of a module, since unpickling requires them to be importable
 
447
from that module.</p>
 
448
<div class="admonition note">
 
449
<p class="first admonition-title">Note</p>
 
450
<p class="last">With pickle protocol version 4 it is possible to easily pickle enums
 
451
nested in other classes.</p>
 
452
</div>
 
453
<p>It is possible to modify how Enum members are pickled/unpickled by defining
 
454
<a class="reference internal" href="pickle.html#object.__reduce_ex__" title="object.__reduce_ex__"><code class="xref py py-meth docutils literal"><span class="pre">__reduce_ex__()</span></code></a> in the enumeration class.</p>
 
455
</div>
 
456
<div class="section" id="functional-api">
 
457
<h2>8.13.11. Functional API<a class="headerlink" href="#functional-api" title="Permalink to this headline">¶</a></h2>
 
458
<p>The <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> class is callable, providing the following functional API:</p>
 
459
<div class="highlight-python3"><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>
 
460
<span class="gp">&gt;&gt;&gt; </span><span class="n">Animal</span>
 
461
<span class="go">&lt;enum &#39;Animal&#39;&gt;</span>
 
462
<span class="gp">&gt;&gt;&gt; </span><span class="n">Animal</span><span class="o">.</span><span class="n">ant</span>
 
463
<span class="go">&lt;Animal.ant: 1&gt;</span>
 
464
<span class="gp">&gt;&gt;&gt; </span><span class="n">Animal</span><span class="o">.</span><span class="n">ant</span><span class="o">.</span><span class="n">value</span>
 
465
<span class="go">1</span>
 
466
<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>
 
467
<span class="go">[&lt;Animal.ant: 1&gt;, &lt;Animal.bee: 2&gt;, &lt;Animal.cat: 3&gt;, &lt;Animal.dog: 4&gt;]</span>
 
468
</pre></div>
 
469
</div>
 
470
<p>The semantics of this API resemble <a class="reference internal" href="collections.html#collections.namedtuple" title="collections.namedtuple"><code class="xref py py-class docutils literal"><span class="pre">namedtuple</span></code></a>. The first
 
471
argument of the call to <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> is the name of the enumeration.</p>
 
472
<p>The second argument is the <em>source</em> of enumeration member names.  It can be a
 
473
whitespace-separated string of names, a sequence of names, a sequence of
 
474
2-tuples with key/value pairs, or a mapping (e.g. dictionary) of names to
 
475
values.  The last two options enable assigning arbitrary values to
 
476
enumerations; the others auto-assign increasing integers starting with 1 (use
 
477
the <code class="docutils literal"><span class="pre">start</span></code> parameter to specify a different starting value).  A
 
478
new class derived from <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> is returned.  In other words, the above
 
479
assignment to <code class="xref py py-class docutils literal"><span class="pre">Animal</span></code> is equivalent to:</p>
 
480
<div class="highlight-python3"><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>
 
481
<span class="gp">... </span>    <span class="n">ant</span> <span class="o">=</span> <span class="mi">1</span>
 
482
<span class="gp">... </span>    <span class="n">bee</span> <span class="o">=</span> <span class="mi">2</span>
 
483
<span class="gp">... </span>    <span class="n">cat</span> <span class="o">=</span> <span class="mi">3</span>
 
484
<span class="gp">... </span>    <span class="n">dog</span> <span class="o">=</span> <span class="mi">4</span>
 
485
<span class="gp">...</span>
 
486
</pre></div>
 
487
</div>
 
488
<p>The reason for defaulting to <code class="docutils literal"><span class="pre">1</span></code> as the starting number and not <code class="docutils literal"><span class="pre">0</span></code> is
 
489
that <code class="docutils literal"><span class="pre">0</span></code> is <code class="docutils literal"><span class="pre">False</span></code> in a boolean sense, but enum members all evaluate
 
490
to <code class="docutils literal"><span class="pre">True</span></code>.</p>
 
491
<p>Pickling enums created with the functional API can be tricky as frame stack
 
492
implementation details are used to try and figure out which module the
 
493
enumeration is being created in (e.g. it will fail if you use a utility
 
494
function in separate module, and also may not work on IronPython or Jython).
 
495
The solution is to specify the module name explicitly as follows:</p>
 
496
<div class="highlight-python3"><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="n">__name__</span><span class="p">)</span>
 
497
</pre></div>
 
498
</div>
 
499
<div class="admonition warning">
 
500
<p class="first admonition-title">Warning</p>
 
501
<p class="last">If <code class="docutils literal"><span class="pre">module</span></code> is not supplied, and Enum cannot determine what it is,
 
502
the new Enum members will not be unpicklable; to keep errors closer to
 
503
the source, pickling will be disabled.</p>
 
504
</div>
 
505
<p>The new pickle protocol 4 also, in some circumstances, relies on
 
506
<a class="reference internal" href="stdtypes.html#definition.__qualname__" title="definition.__qualname__"><code class="xref py py-attr docutils literal"><span class="pre">__qualname__</span></code></a> being set to the location where pickle will be able
 
507
to find the class.  For example, if the class was made available in class
 
508
SomeData in the global scope:</p>
 
509
<div class="highlight-python3"><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>
 
510
</pre></div>
 
511
</div>
 
512
<p>The complete signature is:</p>
 
513
<div class="highlight-python3"><div class="highlight"><pre><span></span><span class="n">Enum</span><span class="p">(</span><span class="n">value</span><span class="o">=</span><span class="s1">&#39;NewEnumName&#39;</span><span class="p">,</span> <span class="n">names</span><span class="o">=&lt;...&gt;</span><span class="p">,</span> <span class="o">*</span><span class="p">,</span> <span class="n">module</span><span class="o">=</span><span class="s1">&#39;...&#39;</span><span class="p">,</span> <span class="n">qualname</span><span class="o">=</span><span class="s1">&#39;...&#39;</span><span class="p">,</span> <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> <span class="n">start</span><span class="o">=</span><span class="mi">1</span><span class="p">)</span>
 
514
</pre></div>
 
515
</div>
 
516
<table class="docutils field-list" frame="void" rules="none">
 
517
<col class="field-name" />
 
518
<col class="field-body" />
 
519
<tbody valign="top">
 
520
<tr class="field-odd field"><th class="field-name">value:</th><td class="field-body"><p class="first">What the new Enum class will record as its name.</p>
 
521
</td>
 
522
</tr>
 
523
<tr class="field-even field"><th class="field-name">names:</th><td class="field-body"><p class="first">The Enum members.  This can be a whitespace or comma separated string
 
524
(values will start at 1 unless otherwise specified):</p>
 
525
<div class="highlight-python3"><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>
 
526
</pre></div>
 
527
</div>
 
528
<p>or an iterator of names:</p>
 
529
<div class="highlight-python3"><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>
 
530
</pre></div>
 
531
</div>
 
532
<p>or an iterator of (name, value) pairs:</p>
 
533
<div class="highlight-python3"><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>
 
534
</pre></div>
 
535
</div>
 
536
<p>or a mapping:</p>
 
537
<div class="highlight-python3"><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>
 
538
</pre></div>
 
539
</div>
 
540
</td>
 
541
</tr>
 
542
<tr class="field-odd field"><th class="field-name">module:</th><td class="field-body"><p class="first">name of module where new Enum class can be found.</p>
 
543
</td>
 
544
</tr>
 
545
<tr class="field-even field"><th class="field-name">qualname:</th><td class="field-body"><p class="first">where in module new Enum class can be found.</p>
 
546
</td>
 
547
</tr>
 
548
<tr class="field-odd field"><th class="field-name">type:</th><td class="field-body"><p class="first">type to mix in to new Enum class.</p>
 
549
</td>
 
550
</tr>
 
551
<tr class="field-even field"><th class="field-name">start:</th><td class="field-body"><p class="first last">number to start counting at if only names are passed in.</p>
 
552
</td>
 
553
</tr>
 
554
</tbody>
 
555
</table>
 
556
<div class="versionchanged">
 
557
<p><span class="versionmodified">Changed in version 3.5: </span>The <em>start</em> parameter was added.</p>
 
558
</div>
 
559
</div>
 
560
<div class="section" id="derived-enumerations">
 
561
<h2>8.13.12. Derived Enumerations<a class="headerlink" href="#derived-enumerations" title="Permalink to this headline">¶</a></h2>
 
562
<div class="section" id="intenum">
 
563
<h3>8.13.12.1. IntEnum<a class="headerlink" href="#intenum" title="Permalink to this headline">¶</a></h3>
 
564
<p>A variation of <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> is provided which is also a subclass of
 
565
<a class="reference internal" href="functions.html#int" title="int"><code class="xref py py-class docutils literal"><span class="pre">int</span></code></a>.  Members of an <a class="reference internal" href="#enum.IntEnum" title="enum.IntEnum"><code class="xref py py-class docutils literal"><span class="pre">IntEnum</span></code></a> can be compared to integers;
 
566
by extension, integer enumerations of different types can also be compared
 
567
to each other:</p>
 
568
<div class="highlight-python3"><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="k">import</span> <span class="n">IntEnum</span>
 
569
<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>
 
570
<span class="gp">... </span>    <span class="n">circle</span> <span class="o">=</span> <span class="mi">1</span>
 
571
<span class="gp">... </span>    <span class="n">square</span> <span class="o">=</span> <span class="mi">2</span>
 
572
<span class="gp">...</span>
 
573
<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>
 
574
<span class="gp">... </span>    <span class="n">post</span> <span class="o">=</span> <span class="mi">1</span>
 
575
<span class="gp">... </span>    <span class="n">get</span> <span class="o">=</span> <span class="mi">2</span>
 
576
<span class="gp">...</span>
 
577
<span class="gp">&gt;&gt;&gt; </span><span class="n">Shape</span> <span class="o">==</span> <span class="mi">1</span>
 
578
<span class="go">False</span>
 
579
<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>
 
580
<span class="go">True</span>
 
581
<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>
 
582
<span class="go">True</span>
 
583
</pre></div>
 
584
</div>
 
585
<p>However, they still can&#8217;t be compared to standard <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> enumerations:</p>
 
586
<div class="highlight-python3"><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>
 
587
<span class="gp">... </span>    <span class="n">circle</span> <span class="o">=</span> <span class="mi">1</span>
 
588
<span class="gp">... </span>    <span class="n">square</span> <span class="o">=</span> <span class="mi">2</span>
 
589
<span class="gp">...</span>
 
590
<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>
 
591
<span class="gp">... </span>    <span class="n">red</span> <span class="o">=</span> <span class="mi">1</span>
 
592
<span class="gp">... </span>    <span class="n">green</span> <span class="o">=</span> <span class="mi">2</span>
 
593
<span class="gp">...</span>
 
594
<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>
 
595
<span class="go">False</span>
 
596
</pre></div>
 
597
</div>
 
598
<p><a class="reference internal" href="#enum.IntEnum" title="enum.IntEnum"><code class="xref py py-class docutils literal"><span class="pre">IntEnum</span></code></a> values behave like integers in other ways you&#8217;d expect:</p>
 
599
<div class="highlight-python3"><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>
 
600
<span class="go">1</span>
 
601
<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>
 
602
<span class="go">&#39;b&#39;</span>
 
603
<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>
 
604
<span class="go">[0, 1]</span>
 
605
</pre></div>
 
606
</div>
 
607
<p>For the vast majority of code, <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> is strongly recommended,
 
608
since <a class="reference internal" href="#enum.IntEnum" title="enum.IntEnum"><code class="xref py py-class docutils literal"><span class="pre">IntEnum</span></code></a> breaks some semantic promises of an enumeration (by
 
609
being comparable to integers, and thus by transitivity to other
 
610
unrelated enumerations).  It should be used only in special cases where
 
611
there&#8217;s no other choice; for example, when integer constants are
 
612
replaced with enumerations and backwards compatibility is required with code
 
613
that still expects integers.</p>
 
614
</div>
 
615
<div class="section" id="others">
 
616
<h3>8.13.12.2. Others<a class="headerlink" href="#others" title="Permalink to this headline">¶</a></h3>
 
617
<p>While <a class="reference internal" href="#enum.IntEnum" title="enum.IntEnum"><code class="xref py py-class docutils literal"><span class="pre">IntEnum</span></code></a> is part of the <a class="reference internal" href="#module-enum" title="enum: Implementation of an enumeration class."><code class="xref py py-mod docutils literal"><span class="pre">enum</span></code></a> module, it would be very
 
618
simple to implement independently:</p>
 
619
<div class="highlight-python3"><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>
 
620
    <span class="k">pass</span>
 
621
</pre></div>
 
622
</div>
 
623
<p>This demonstrates how similar derived enumerations can be defined; for example
 
624
a <code class="xref py py-class docutils literal"><span class="pre">StrEnum</span></code> that mixes in <a class="reference internal" href="stdtypes.html#str" title="str"><code class="xref py py-class docutils literal"><span class="pre">str</span></code></a> instead of <a class="reference internal" href="functions.html#int" title="int"><code class="xref py py-class docutils literal"><span class="pre">int</span></code></a>.</p>
 
625
<p>Some rules:</p>
 
626
<ol class="arabic simple">
 
627
<li>When subclassing <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a>, mix-in types must appear before
 
628
<a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> itself in the sequence of bases, as in the <a class="reference internal" href="#enum.IntEnum" title="enum.IntEnum"><code class="xref py py-class docutils literal"><span class="pre">IntEnum</span></code></a>
 
629
example above.</li>
 
630
<li>While <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> can have members of any type, once you mix in an
 
631
additional type, all the members must have values of that type, e.g.
 
632
<a class="reference internal" href="functions.html#int" title="int"><code class="xref py py-class docutils literal"><span class="pre">int</span></code></a> above.  This restriction does not apply to mix-ins which only
 
633
add methods and don&#8217;t specify another data type such as <a class="reference internal" href="functions.html#int" title="int"><code class="xref py py-class docutils literal"><span class="pre">int</span></code></a> or
 
634
<a class="reference internal" href="stdtypes.html#str" title="str"><code class="xref py py-class docutils literal"><span class="pre">str</span></code></a>.</li>
 
635
<li>When another data type is mixed in, the <code class="xref py py-attr docutils literal"><span class="pre">value</span></code> attribute is <em>not the
 
636
same</em> as the enum member itself, although it is equivalent and will compare
 
637
equal.</li>
 
638
<li>%-style formatting:  <cite>%s</cite> and <cite>%r</cite> call the <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> class&#8217;s
 
639
<a class="reference internal" href="../reference/datamodel.html#object.__str__" title="object.__str__"><code class="xref py py-meth docutils literal"><span class="pre">__str__()</span></code></a> and <a class="reference internal" href="../reference/datamodel.html#object.__repr__" title="object.__repr__"><code class="xref py py-meth docutils literal"><span class="pre">__repr__()</span></code></a> respectively; other codes (such as
 
640
<cite>%i</cite> or <cite>%h</cite> for IntEnum) treat the enum member as its mixed-in type.</li>
 
641
<li><a class="reference internal" href="stdtypes.html#str.format" title="str.format"><code class="xref py py-meth docutils literal"><span class="pre">str.format()</span></code></a> (or <a class="reference internal" href="functions.html#format" title="format"><code class="xref py py-func docutils literal"><span class="pre">format()</span></code></a>) will use the mixed-in
 
642
type&#8217;s <a class="reference internal" href="../reference/datamodel.html#object.__format__" title="object.__format__"><code class="xref py py-meth docutils literal"><span class="pre">__format__()</span></code></a>.  If the <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> class&#8217;s <a class="reference internal" href="stdtypes.html#str" title="str"><code class="xref py py-func docutils literal"><span class="pre">str()</span></code></a> or
 
643
<a class="reference internal" href="functions.html#repr" title="repr"><code class="xref py py-func docutils literal"><span class="pre">repr()</span></code></a> is desired, use the <cite>!s</cite> or <cite>!r</cite> format codes.</li>
 
644
</ol>
 
645
</div>
 
646
</div>
 
647
<div class="section" id="interesting-examples">
 
648
<h2>8.13.13. Interesting examples<a class="headerlink" href="#interesting-examples" title="Permalink to this headline">¶</a></h2>
 
649
<p>While <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> and <a class="reference internal" href="#enum.IntEnum" title="enum.IntEnum"><code class="xref py py-class docutils literal"><span class="pre">IntEnum</span></code></a> are expected to cover the majority of
 
650
use-cases, they cannot cover them all.  Here are recipes for some different
 
651
types of enumerations that can be used directly, or as examples for creating
 
652
one&#8217;s own.</p>
 
653
<div class="section" id="autonumber">
 
654
<h3>8.13.13.1. AutoNumber<a class="headerlink" href="#autonumber" title="Permalink to this headline">¶</a></h3>
 
655
<p>Avoids having to specify the value for each enumeration member:</p>
 
656
<div class="highlight-python3"><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>
 
657
<span class="gp">... </span>    <span class="k">def</span> <span class="nf">__new__</span><span class="p">(</span><span class="n">cls</span><span class="p">):</span>
 
658
<span class="gp">... </span>        <span class="n">value</span> <span class="o">=</span> <span class="nb">len</span><span class="p">(</span><span class="n">cls</span><span class="o">.</span><span class="n">__members__</span><span class="p">)</span> <span class="o">+</span> <span class="mi">1</span>
 
659
<span class="gp">... </span>        <span class="n">obj</span> <span class="o">=</span> <span class="nb">object</span><span class="o">.</span><span class="n">__new__</span><span class="p">(</span><span class="n">cls</span><span class="p">)</span>
 
660
<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>
 
661
<span class="gp">... </span>        <span class="k">return</span> <span class="n">obj</span>
 
662
<span class="gp">...</span>
 
663
<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>
 
664
<span class="gp">... </span>    <span class="n">red</span> <span class="o">=</span> <span class="p">()</span>
 
665
<span class="gp">... </span>    <span class="n">green</span> <span class="o">=</span> <span class="p">()</span>
 
666
<span class="gp">... </span>    <span class="n">blue</span> <span class="o">=</span> <span class="p">()</span>
 
667
<span class="gp">...</span>
 
668
<span class="gp">&gt;&gt;&gt; </span><span class="n">Color</span><span class="o">.</span><span class="n">green</span><span class="o">.</span><span class="n">value</span> <span class="o">==</span> <span class="mi">2</span>
 
669
<span class="go">True</span>
 
670
</pre></div>
 
671
</div>
 
672
<div class="admonition note">
 
673
<p class="first admonition-title">Note</p>
 
674
<p class="last">The <a class="reference internal" href="../reference/datamodel.html#object.__new__" title="object.__new__"><code class="xref py py-meth docutils literal"><span class="pre">__new__()</span></code></a> method, if defined, is used during creation of the Enum
 
675
members; it is then replaced by Enum&#8217;s <a class="reference internal" href="../reference/datamodel.html#object.__new__" title="object.__new__"><code class="xref py py-meth docutils literal"><span class="pre">__new__()</span></code></a> which is used after
 
676
class creation for lookup of existing members.</p>
 
677
</div>
 
678
</div>
 
679
<div class="section" id="orderedenum">
 
680
<h3>8.13.13.2. OrderedEnum<a class="headerlink" href="#orderedenum" title="Permalink to this headline">¶</a></h3>
 
681
<p>An ordered enumeration that is not based on <a class="reference internal" href="#enum.IntEnum" title="enum.IntEnum"><code class="xref py py-class docutils literal"><span class="pre">IntEnum</span></code></a> and so maintains
 
682
the normal <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> invariants (such as not being comparable to other
 
683
enumerations):</p>
 
684
<div class="highlight-python3"><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>
 
685
<span class="gp">... </span>    <span class="k">def</span> <span class="nf">__ge__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">other</span><span class="p">):</span>
 
686
<span class="gp">... </span>        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">__class__</span> <span class="ow">is</span> <span class="n">other</span><span class="o">.</span><span class="n">__class__</span><span class="p">:</span>
 
687
<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>
 
688
<span class="gp">... </span>        <span class="k">return</span> <span class="bp">NotImplemented</span>
 
689
<span class="gp">... </span>    <span class="k">def</span> <span class="nf">__gt__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">other</span><span class="p">):</span>
 
690
<span class="gp">... </span>        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">__class__</span> <span class="ow">is</span> <span class="n">other</span><span class="o">.</span><span class="n">__class__</span><span class="p">:</span>
 
691
<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>
 
692
<span class="gp">... </span>        <span class="k">return</span> <span class="bp">NotImplemented</span>
 
693
<span class="gp">... </span>    <span class="k">def</span> <span class="nf">__le__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">other</span><span class="p">):</span>
 
694
<span class="gp">... </span>        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">__class__</span> <span class="ow">is</span> <span class="n">other</span><span class="o">.</span><span class="n">__class__</span><span class="p">:</span>
 
695
<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>
 
696
<span class="gp">... </span>        <span class="k">return</span> <span class="bp">NotImplemented</span>
 
697
<span class="gp">... </span>    <span class="k">def</span> <span class="nf">__lt__</span><span class="p">(</span><span class="bp">self</span><span class="p">,</span> <span class="n">other</span><span class="p">):</span>
 
698
<span class="gp">... </span>        <span class="k">if</span> <span class="bp">self</span><span class="o">.</span><span class="n">__class__</span> <span class="ow">is</span> <span class="n">other</span><span class="o">.</span><span class="n">__class__</span><span class="p">:</span>
 
699
<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>
 
700
<span class="gp">... </span>        <span class="k">return</span> <span class="bp">NotImplemented</span>
 
701
<span class="gp">...</span>
 
702
<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>
 
703
<span class="gp">... </span>    <span class="n">A</span> <span class="o">=</span> <span class="mi">5</span>
 
704
<span class="gp">... </span>    <span class="n">B</span> <span class="o">=</span> <span class="mi">4</span>
 
705
<span class="gp">... </span>    <span class="n">C</span> <span class="o">=</span> <span class="mi">3</span>
 
706
<span class="gp">... </span>    <span class="n">D</span> <span class="o">=</span> <span class="mi">2</span>
 
707
<span class="gp">... </span>    <span class="n">F</span> <span class="o">=</span> <span class="mi">1</span>
 
708
<span class="gp">...</span>
 
709
<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>
 
710
<span class="go">True</span>
 
711
</pre></div>
 
712
</div>
 
713
</div>
 
714
<div class="section" id="duplicatefreeenum">
 
715
<h3>8.13.13.3. DuplicateFreeEnum<a class="headerlink" href="#duplicatefreeenum" title="Permalink to this headline">¶</a></h3>
 
716
<p>Raises an error if a duplicate member name is found instead of creating an
 
717
alias:</p>
 
718
<div class="highlight-python3"><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>
 
719
<span class="gp">... </span>    <span class="k">def</span> <span class="nf">__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>
 
720
<span class="gp">... </span>        <span class="n">cls</span> <span class="o">=</span> <span class="bp">self</span><span class="o">.</span><span class="n">__class__</span>
 
721
<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="n">cls</span><span class="p">):</span>
 
722
<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>
 
723
<span class="gp">... </span>            <span class="n">e</span> <span class="o">=</span> <span class="n">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>
 
724
<span class="gp">... </span>            <span class="k">raise</span> <span class="ne">ValueError</span><span class="p">(</span>
 
725
<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>
 
726
<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>
 
727
<span class="gp">...</span>
 
728
<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>
 
729
<span class="gp">... </span>    <span class="n">red</span> <span class="o">=</span> <span class="mi">1</span>
 
730
<span class="gp">... </span>    <span class="n">green</span> <span class="o">=</span> <span class="mi">2</span>
 
731
<span class="gp">... </span>    <span class="n">blue</span> <span class="o">=</span> <span class="mi">3</span>
 
732
<span class="gp">... </span>    <span class="n">grene</span> <span class="o">=</span> <span class="mi">2</span>
 
733
<span class="gp">...</span>
 
734
<span class="gt">Traceback (most recent call last):</span>
 
735
<span class="c">...</span>
 
736
<span class="gr">ValueError</span>: <span class="n">aliases not allowed in DuplicateFreeEnum:  &#39;grene&#39; --&gt; &#39;green&#39;</span>
 
737
</pre></div>
 
738
</div>
 
739
<div class="admonition note">
 
740
<p class="first admonition-title">Note</p>
 
741
<p class="last">This is a useful example for subclassing Enum to add or change other
 
742
behaviors as well as disallowing aliases.  If the only desired change is
 
743
disallowing aliases, the <a class="reference internal" href="#enum.unique" title="enum.unique"><code class="xref py py-func docutils literal"><span class="pre">unique()</span></code></a> decorator can be used instead.</p>
 
744
</div>
 
745
</div>
 
746
<div class="section" id="planet">
 
747
<h3>8.13.13.4. Planet<a class="headerlink" href="#planet" title="Permalink to this headline">¶</a></h3>
 
748
<p>If <a class="reference internal" href="../reference/datamodel.html#object.__new__" title="object.__new__"><code class="xref py py-meth docutils literal"><span class="pre">__new__()</span></code></a> or <a class="reference internal" href="../reference/datamodel.html#object.__init__" title="object.__init__"><code class="xref py py-meth docutils literal"><span class="pre">__init__()</span></code></a> is defined the value of the enum member
 
749
will be passed to those methods:</p>
 
750
<div class="highlight-python3"><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>
 
751
<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>
 
752
<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>
 
753
<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>
 
754
<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>
 
755
<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>
 
756
<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>
 
757
<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>
 
758
<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>
 
759
<span class="gp">... </span>    <span class="k">def</span> <span class="nf">__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>
 
760
<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>
 
761
<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>
 
762
<span class="gp">... </span>    <span class="nd">@property</span>
 
763
<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>
 
764
<span class="gp">... </span>        <span class="c1"># universal gravitational constant  (m3 kg-1 s-2)</span>
 
765
<span class="gp">... </span>        <span class="n">G</span> <span class="o">=</span> <span class="mf">6.67300E-11</span>
 
766
<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>
 
767
<span class="gp">...</span>
 
768
<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>
 
769
<span class="go">(5.976e+24, 6378140.0)</span>
 
770
<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>
 
771
<span class="go">9.802652743337129</span>
 
772
</pre></div>
 
773
</div>
 
774
</div>
 
775
</div>
 
776
<div class="section" id="how-are-enums-different">
 
777
<h2>8.13.14. How are Enums different?<a class="headerlink" href="#how-are-enums-different" title="Permalink to this headline">¶</a></h2>
 
778
<p>Enums have a custom metaclass that affects many aspects of both derived Enum
 
779
classes and their instances (members).</p>
 
780
<div class="section" id="enum-classes">
 
781
<h3>8.13.14.1. Enum Classes<a class="headerlink" href="#enum-classes" title="Permalink to this headline">¶</a></h3>
 
782
<p>The <code class="xref py py-class docutils literal"><span class="pre">EnumMeta</span></code> metaclass is responsible for providing the
 
783
<a class="reference internal" href="../reference/datamodel.html#object.__contains__" title="object.__contains__"><code class="xref py py-meth docutils literal"><span class="pre">__contains__()</span></code></a>, <a class="reference internal" href="../reference/datamodel.html#object.__dir__" title="object.__dir__"><code class="xref py py-meth docutils literal"><span class="pre">__dir__()</span></code></a>, <a class="reference internal" href="../reference/datamodel.html#object.__iter__" title="object.__iter__"><code class="xref py py-meth docutils literal"><span class="pre">__iter__()</span></code></a> and other methods that
 
784
allow one to do things with an <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> class that fail on a typical
 
785
class, such as <cite>list(Color)</cite> or <cite>some_var in Color</cite>.  <code class="xref py py-class docutils literal"><span class="pre">EnumMeta</span></code> is
 
786
responsible for ensuring that various other methods on the final <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a>
 
787
class are correct (such as <a class="reference internal" href="../reference/datamodel.html#object.__new__" title="object.__new__"><code class="xref py py-meth docutils literal"><span class="pre">__new__()</span></code></a>, <a class="reference internal" href="pickle.html#object.__getnewargs__" title="object.__getnewargs__"><code class="xref py py-meth docutils literal"><span class="pre">__getnewargs__()</span></code></a>,
 
788
<a class="reference internal" href="../reference/datamodel.html#object.__str__" title="object.__str__"><code class="xref py py-meth docutils literal"><span class="pre">__str__()</span></code></a> and <a class="reference internal" href="../reference/datamodel.html#object.__repr__" title="object.__repr__"><code class="xref py py-meth docutils literal"><span class="pre">__repr__()</span></code></a>).</p>
 
789
</div>
 
790
<div class="section" id="enum-members-aka-instances">
 
791
<h3>8.13.14.2. Enum Members (aka instances)<a class="headerlink" href="#enum-members-aka-instances" title="Permalink to this headline">¶</a></h3>
 
792
<p>The most interesting thing about Enum members is that they are singletons.
 
793
<code class="xref py py-class docutils literal"><span class="pre">EnumMeta</span></code> creates them all while it is creating the <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a>
 
794
class itself, and then puts a custom <a class="reference internal" href="../reference/datamodel.html#object.__new__" title="object.__new__"><code class="xref py py-meth docutils literal"><span class="pre">__new__()</span></code></a> in place to ensure
 
795
that no new ones are ever instantiated by returning only the existing
 
796
member instances.</p>
 
797
</div>
 
798
<div class="section" id="finer-points">
 
799
<h3>8.13.14.3. Finer Points<a class="headerlink" href="#finer-points" title="Permalink to this headline">¶</a></h3>
 
800
<p><a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> members are instances of an <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> class, and even
 
801
though they are accessible as <cite>EnumClass.member</cite>, they should not be accessed
 
802
directly from the member as that lookup may fail or, worse, return something
 
803
besides the <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> member you looking for:</p>
 
804
<div class="highlight-python3"><div class="highlight"><pre><span></span><span class="gp">&gt;&gt;&gt; </span><span class="k">class</span> <span class="nc">FieldTypes</span><span class="p">(</span><span class="n">Enum</span><span class="p">):</span>
 
805
<span class="gp">... </span>    <span class="n">name</span> <span class="o">=</span> <span class="mi">0</span>
 
806
<span class="gp">... </span>    <span class="n">value</span> <span class="o">=</span> <span class="mi">1</span>
 
807
<span class="gp">... </span>    <span class="n">size</span> <span class="o">=</span> <span class="mi">2</span>
 
808
<span class="gp">...</span>
 
809
<span class="gp">&gt;&gt;&gt; </span><span class="n">FieldTypes</span><span class="o">.</span><span class="n">value</span><span class="o">.</span><span class="n">size</span>
 
810
<span class="go">&lt;FieldTypes.size: 2&gt;</span>
 
811
<span class="gp">&gt;&gt;&gt; </span><span class="n">FieldTypes</span><span class="o">.</span><span class="n">size</span><span class="o">.</span><span class="n">value</span>
 
812
<span class="go">2</span>
 
813
</pre></div>
 
814
</div>
 
815
<div class="versionchanged">
 
816
<p><span class="versionmodified">Changed in version 3.5.</span></p>
 
817
</div>
 
818
<p>The <code class="xref py py-attr docutils literal"><span class="pre">__members__</span></code> attribute is only available on the class.</p>
 
819
<p>If you give your <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> subclass extra methods, like the <a class="reference internal" href="#planet">Planet</a>
 
820
class above, those methods will show up in a <a class="reference internal" href="functions.html#dir" title="dir"><code class="xref py py-func docutils literal"><span class="pre">dir()</span></code></a> of the member,
 
821
but not of the class:</p>
 
822
<div class="highlight-python3"><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>
 
823
<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>
 
824
<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>
 
825
<span class="go">[&#39;__class__&#39;, &#39;__doc__&#39;, &#39;__module__&#39;, &#39;name&#39;, &#39;surface_gravity&#39;, &#39;value&#39;]</span>
 
826
</pre></div>
 
827
</div>
 
828
<p>The <a class="reference internal" href="../reference/datamodel.html#object.__new__" title="object.__new__"><code class="xref py py-meth docutils literal"><span class="pre">__new__()</span></code></a> method will only be used for the creation of the
 
829
<a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> members &#8211; after that it is replaced.  Any custom <a class="reference internal" href="../reference/datamodel.html#object.__new__" title="object.__new__"><code class="xref py py-meth docutils literal"><span class="pre">__new__()</span></code></a>
 
830
method must create the object and set the <code class="xref py py-attr docutils literal"><span class="pre">_value_</span></code> attribute
 
831
appropriately.</p>
 
832
<p>If you wish to change how <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a> members are looked up you should either
 
833
write a helper function or a <a class="reference internal" href="functions.html#classmethod" title="classmethod"><code class="xref py py-func docutils literal"><span class="pre">classmethod()</span></code></a> for the <a class="reference internal" href="#enum.Enum" title="enum.Enum"><code class="xref py py-class docutils literal"><span class="pre">Enum</span></code></a>
 
834
subclass.</p>
 
835
</div>
 
836
</div>
 
837
</div>
 
838
 
 
839
 
 
840
          </div>
 
841
        </div>
 
842
      </div>
 
843
      <div class="sphinxsidebar" role="navigation" aria-label="main navigation">
 
844
        <div class="sphinxsidebarwrapper">
 
845
  <h3><a href="../contents.html">Table Of Contents</a></h3>
 
846
  <ul>
 
847
<li><a class="reference internal" href="#">8.13. <code class="docutils literal"><span class="pre">enum</span></code> &#8212; Support for enumerations</a><ul>
 
848
<li><a class="reference internal" href="#module-contents">8.13.1. Module Contents</a></li>
 
849
<li><a class="reference internal" href="#creating-an-enum">8.13.2. Creating an Enum</a></li>
 
850
<li><a class="reference internal" href="#programmatic-access-to-enumeration-members-and-their-attributes">8.13.3. Programmatic access to enumeration members and their attributes</a></li>
 
851
<li><a class="reference internal" href="#duplicating-enum-members-and-values">8.13.4. Duplicating enum members and values</a></li>
 
852
<li><a class="reference internal" href="#ensuring-unique-enumeration-values">8.13.5. Ensuring unique enumeration values</a></li>
 
853
<li><a class="reference internal" href="#iteration">8.13.6. Iteration</a></li>
 
854
<li><a class="reference internal" href="#comparisons">8.13.7. Comparisons</a></li>
 
855
<li><a class="reference internal" href="#allowed-members-and-attributes-of-enumerations">8.13.8. Allowed members and attributes of enumerations</a></li>
 
856
<li><a class="reference internal" href="#restricted-subclassing-of-enumerations">8.13.9. Restricted subclassing of enumerations</a></li>
 
857
<li><a class="reference internal" href="#pickling">8.13.10. Pickling</a></li>
 
858
<li><a class="reference internal" href="#functional-api">8.13.11. Functional API</a></li>
 
859
<li><a class="reference internal" href="#derived-enumerations">8.13.12. Derived Enumerations</a><ul>
 
860
<li><a class="reference internal" href="#intenum">8.13.12.1. IntEnum</a></li>
 
861
<li><a class="reference internal" href="#others">8.13.12.2. Others</a></li>
 
862
</ul>
 
863
</li>
 
864
<li><a class="reference internal" href="#interesting-examples">8.13.13. Interesting examples</a><ul>
 
865
<li><a class="reference internal" href="#autonumber">8.13.13.1. AutoNumber</a></li>
 
866
<li><a class="reference internal" href="#orderedenum">8.13.13.2. OrderedEnum</a></li>
 
867
<li><a class="reference internal" href="#duplicatefreeenum">8.13.13.3. DuplicateFreeEnum</a></li>
 
868
<li><a class="reference internal" href="#planet">8.13.13.4. Planet</a></li>
 
869
</ul>
 
870
</li>
 
871
<li><a class="reference internal" href="#how-are-enums-different">8.13.14. How are Enums different?</a><ul>
 
872
<li><a class="reference internal" href="#enum-classes">8.13.14.1. Enum Classes</a></li>
 
873
<li><a class="reference internal" href="#enum-members-aka-instances">8.13.14.2. Enum Members (aka instances)</a></li>
 
874
<li><a class="reference internal" href="#finer-points">8.13.14.3. Finer Points</a></li>
 
875
</ul>
 
876
</li>
 
877
</ul>
 
878
</li>
 
879
</ul>
 
880
 
 
881
  <h4>Previous topic</h4>
 
882
  <p class="topless"><a href="reprlib.html"
 
883
                        title="previous chapter">8.12. <code class="docutils literal"><span class="pre">reprlib</span></code> &#8212; Alternate <code class="docutils literal"><span class="pre">repr()</span></code> implementation</a></p>
 
884
  <h4>Next topic</h4>
 
885
  <p class="topless"><a href="numeric.html"
 
886
                        title="next chapter">9. Numeric and Mathematical Modules</a></p>
 
887
  <div role="note" aria-label="source link">
 
888
    <h3>This Page</h3>
 
889
    <ul class="this-page-menu">
 
890
      <li><a href="../bugs.html">Report a Bug</a></li>
 
891
      <li><a href="../_sources/library/enum.txt"
 
892
            rel="nofollow">Show Source</a></li>
 
893
    </ul>
 
894
  </div>
 
895
        </div>
 
896
      </div>
 
897
      <div class="clearer"></div>
 
898
    </div>  
 
899
    <div class="related" role="navigation" aria-label="related navigation">
 
900
      <h3>Navigation</h3>
 
901
      <ul>
 
902
        <li class="right" style="margin-right: 10px">
 
903
          <a href="../genindex.html" title="General Index"
 
904
             >index</a></li>
 
905
        <li class="right" >
 
906
          <a href="../py-modindex.html" title="Python Module Index"
 
907
             >modules</a> |</li>
 
908
        <li class="right" >
 
909
          <a href="numeric.html" title="9. Numeric and Mathematical Modules"
 
910
             >next</a> |</li>
 
911
        <li class="right" >
 
912
          <a href="reprlib.html" title="8.12. reprlib — Alternate repr() implementation"
 
913
             >previous</a> |</li>
 
914
        <li><img src="../_static/py.png" alt=""
 
915
                 style="vertical-align: middle; margin-top: -1px"/></li>
 
916
        <li><a href="https://www.python.org/">Python</a> &raquo;</li>
 
917
        <li>
 
918
          <span class="version_switcher_placeholder">3.5.2</span>
 
919
          <a href="../index.html">Documentation </a> &raquo;
 
920
        </li>
 
921
 
 
922
          <li class="nav-item nav-item-1"><a href="index.html" >The Python Standard Library</a> &raquo;</li>
 
923
          <li class="nav-item nav-item-2"><a href="datatypes.html" >8. Data Types</a> &raquo;</li>
 
924
    <li class="right">
 
925
        
 
926
 
 
927
    <div class="inline-search" style="display: none" role="search">
 
928
        <form class="inline-search" action="../search.html" method="get">
 
929
          <input placeholder="Quick search" type="text" name="q" />
 
930
          <input type="submit" value="Go" />
 
931
          <input type="hidden" name="check_keywords" value="yes" />
 
932
          <input type="hidden" name="area" value="default" />
 
933
        </form>
 
934
    </div>
 
935
    <script type="text/javascript">$('.inline-search').show(0);</script>
 
936
         |
 
937
    </li>
 
938
 
 
939
      </ul>
 
940
    </div>  
 
941
    <div class="footer">
 
942
    &copy; <a href="../copyright.html">Copyright</a> 2001-2016, Python Software Foundation.
 
943
    <br />
 
944
    The Python Software Foundation is a non-profit corporation.
 
945
    <a href="https://www.python.org/psf/donations/">Please donate.</a>
 
946
    <br />
 
947
    Last updated on Sep 23, 2016.
 
948
    <a href="../bugs.html">Found a bug</a>?
 
949
    <br />
 
950
    Created using <a href="http://sphinx.pocoo.org/">Sphinx</a> 1.3.3.
 
951
    </div>
 
952
 
 
953
  </body>
 
954
</html>
 
 
b'\\ No newline at end of file'