summaryrefslogtreecommitdiffstats
path: root/Lib/collections
diff options
context:
space:
mode:
authorRaymond Hettinger <python@rcn.com>2011-03-22 21:07:23 (GMT)
committerRaymond Hettinger <python@rcn.com>2011-03-22 21:07:23 (GMT)
commit9a3f4cbfc338e1d3da5619b709af1d005db26ac1 (patch)
tree9a0665651c28f43d109f817ac219ef515455b97a /Lib/collections
parent50105d38405fd472c7594142a9fa4deb224adc4b (diff)
downloadcpython-9a3f4cbfc338e1d3da5619b709af1d005db26ac1.zip
cpython-9a3f4cbfc338e1d3da5619b709af1d005db26ac1.tar.gz
cpython-9a3f4cbfc338e1d3da5619b709af1d005db26ac1.tar.bz2
Simplify the named tuple template by using the new string format syntax.
Diffstat (limited to 'Lib/collections')
-rw-r--r--Lib/collections/__init__.py30
1 files changed, 15 insertions, 15 deletions
diff --git a/Lib/collections/__init__.py b/Lib/collections/__init__.py
index dcb11c0..fd39ca8 100644
--- a/Lib/collections/__init__.py
+++ b/Lib/collections/__init__.py
@@ -290,46 +290,46 @@ def namedtuple(typename, field_names, verbose=False, rename=False):
# Create and fill-in the class template
numfields = len(field_names)
argtxt = repr(field_names).replace("'", "")[1:-1] # tuple repr without parens or quotes
- reprtxt = ', '.join('%s=%%r' % name for name in field_names)
- template = '''class %(typename)s(tuple):
- '%(typename)s(%(argtxt)s)'
+ reprtxt = ', '.join('{}=%r'.format(name) for name in field_names)
+ template = '''class {typename}(tuple):
+ '{typename}({argtxt})'
__slots__ = ()
- _fields = %(field_names)r
+ _fields = {field_names!r}
- def __new__(_cls, %(argtxt)s):
- 'Create new instance of %(typename)s(%(argtxt)s)'
- return _tuple.__new__(_cls, (%(argtxt)s))
+ def __new__(_cls, {argtxt}):
+ 'Create new instance of {typename}({argtxt})'
+ return _tuple.__new__(_cls, ({argtxt}))
@classmethod
def _make(cls, iterable, new=tuple.__new__, len=len):
- 'Make a new %(typename)s object from a sequence or iterable'
+ 'Make a new {typename} object from a sequence or iterable'
result = new(cls, iterable)
- if len(result) != %(numfields)d:
- raise TypeError('Expected %(numfields)d arguments, got %%d' %% len(result))
+ if len(result) != {numfields:d}:
+ raise TypeError('Expected {numfields:d} arguments, got %d' % len(result))
return result
def __repr__(self):
'Return a nicely formatted representation string'
- return self.__class__.__name__ + '(%(reprtxt)s)' %% self
+ return self.__class__.__name__ + '({reprtxt})' % self
def _asdict(self):
'Return a new OrderedDict which maps field names to their values'
return OrderedDict(zip(self._fields, self))
def _replace(_self, **kwds):
- 'Return a new %(typename)s object replacing specified fields with new values'
- result = _self._make(map(kwds.pop, %(field_names)r, _self))
+ 'Return a new {typename} object replacing specified fields with new values'
+ result = _self._make(map(kwds.pop, {field_names!r}, _self))
if kwds:
- raise ValueError('Got unexpected field names: %%r' %% kwds.keys())
+ raise ValueError('Got unexpected field names: %r' % kwds.keys())
return result
def __getnewargs__(self):
'Return self as a plain tuple. Used by copy and pickle.'
return tuple(self)
- ''' % locals()
+'''.format(**locals())
for i, name in enumerate(field_names):
template += " %s = _property(_itemgetter(%d), doc='Alias for field number %d')\n" % (name, i, i)
if verbose: