blob: 23608b4acecbca381a536ee3ff4f42b90f089d28 [file] [log] [blame]
Skip Montanaro0b874442003-10-03 14:05:26 +00001"""A collection of string operations (most are no longer used).
Guido van Rossumc6360141990-10-13 19:23:40 +00002
Skip Montanaro0b874442003-10-03 14:05:26 +00003Warning: most of the code you see here isn't normally used nowadays.
4Beginning with Python 1.6, many of these functions are implemented as
5methods on the standard string object. They used to be implemented by
6a built-in module called strop, but strop is now obsolete itself.
Guido van Rossum20032041997-12-29 19:26:28 +00007
8Public module variables:
9
10whitespace -- a string containing all characters considered whitespace
11lowercase -- a string containing all characters considered lowercase letters
12uppercase -- a string containing all characters considered uppercase letters
13letters -- a string containing all characters considered letters
14digits -- a string containing all characters considered decimal digits
15hexdigits -- a string containing all characters considered hexadecimal digits
16octdigits -- a string containing all characters considered octal digits
Fred Drakefd64c592000-09-18 19:38:11 +000017punctuation -- a string containing all characters considered punctuation
18printable -- a string containing all characters considered printable
Guido van Rossum20032041997-12-29 19:26:28 +000019
20"""
21
Guido van Rossumc6360141990-10-13 19:23:40 +000022# Some strings for ctype-style character classification
Guido van Rossum8e2ec561993-07-29 09:37:38 +000023whitespace = ' \t\n\r\v\f'
Guido van Rossumc6360141990-10-13 19:23:40 +000024lowercase = 'abcdefghijklmnopqrstuvwxyz'
25uppercase = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
26letters = lowercase + uppercase
Fred Drake960fdf92001-07-20 18:38:26 +000027ascii_lowercase = lowercase
28ascii_uppercase = uppercase
29ascii_letters = ascii_lowercase + ascii_uppercase
Guido van Rossumc6360141990-10-13 19:23:40 +000030digits = '0123456789'
31hexdigits = digits + 'abcdef' + 'ABCDEF'
32octdigits = '01234567'
Tim Peters495ad3c2001-01-15 01:36:40 +000033punctuation = """!"#$%&'()*+,-./:;<=>?@[\]^_`{|}~"""
Fred Drake6b2320f2000-09-18 16:46:17 +000034printable = digits + letters + punctuation + whitespace
Guido van Rossumc6360141990-10-13 19:23:40 +000035
36# Case conversion helpers
Martin v. Löwis5357c652002-10-14 20:03:40 +000037# Use str to convert Unicode literal in case of -U
38l = map(chr, xrange(256))
39_idmap = str('').join(l)
40del l
Guido van Rossumc6360141990-10-13 19:23:40 +000041
Barry Warsaw8bee7612004-08-25 02:22:30 +000042# Functions which aren't available as string methods.
43
44# Capitalize the words in a string, e.g. " aBc dEf " -> "Abc Def".
Barry Warsaw8bee7612004-08-25 02:22:30 +000045def capwords(s, sep=None):
Ezio Melotti9aac2452009-09-26 11:20:53 +000046 """capwords(s [,sep]) -> string
Barry Warsaw8bee7612004-08-25 02:22:30 +000047
48 Split the argument into words using split, capitalize each
49 word using capitalize, and join the capitalized words using
Ezio Melotti9aac2452009-09-26 11:20:53 +000050 join. If the optional second argument sep is absent or None,
51 runs of whitespace characters are replaced by a single space
52 and leading and trailing whitespace are removed, otherwise
53 sep is used to split and join the words.
Barry Warsaw8bee7612004-08-25 02:22:30 +000054
55 """
Ezio Melotti9aac2452009-09-26 11:20:53 +000056 return (sep or ' ').join(x.capitalize() for x in s.split(sep))
Barry Warsaw8bee7612004-08-25 02:22:30 +000057
58
59# Construct a translation string
60_idmapL = None
61def maketrans(fromstr, tostr):
62 """maketrans(frm, to) -> string
63
64 Return a translation table (a string of 256 bytes long)
65 suitable for use in string.translate. The strings frm and to
66 must be of the same length.
67
68 """
69 if len(fromstr) != len(tostr):
70 raise ValueError, "maketrans arguments must have same length"
71 global _idmapL
72 if not _idmapL:
Georg Brandl74bbc792008-07-18 19:06:13 +000073 _idmapL = list(_idmap)
Barry Warsaw8bee7612004-08-25 02:22:30 +000074 L = _idmapL[:]
75 fromstr = map(ord, fromstr)
76 for i in range(len(fromstr)):
77 L[fromstr[i]] = tostr[i]
78 return ''.join(L)
79
80
Raymond Hettinger57aef9c2004-12-07 07:55:07 +000081
Raymond Hettinger0d58e2b2004-08-26 00:21:13 +000082####################################################################
Barry Warsaw8bee7612004-08-25 02:22:30 +000083import re as _re
84
Barry Warsaw46b629c2004-09-13 14:35:04 +000085class _multimap:
86 """Helper class for combining multiple mappings.
87
88 Used by .{safe_,}substitute() to combine the mapping and keyword
89 arguments.
90 """
91 def __init__(self, primary, secondary):
92 self._primary = primary
93 self._secondary = secondary
94
95 def __getitem__(self, key):
96 try:
97 return self._primary[key]
98 except KeyError:
99 return self._secondary[key]
100
101
Barry Warsaw12827c12004-09-10 03:08:08 +0000102class _TemplateMetaclass(type):
103 pattern = r"""
Raymond Hettinger55593c32004-09-26 18:56:44 +0000104 %(delim)s(?:
105 (?P<escaped>%(delim)s) | # Escape sequence of two delimiters
106 (?P<named>%(id)s) | # delimiter and a Python identifier
107 {(?P<braced>%(id)s)} | # delimiter and a braced identifier
108 (?P<invalid>) # Other ill-formed delimiter exprs
109 )
Barry Warsaw12827c12004-09-10 03:08:08 +0000110 """
111
112 def __init__(cls, name, bases, dct):
Guido van Rossumf102e242007-03-23 18:53:03 +0000113 super(_TemplateMetaclass, cls).__init__(name, bases, dct)
Barry Warsaw12827c12004-09-10 03:08:08 +0000114 if 'pattern' in dct:
115 pattern = cls.pattern
116 else:
117 pattern = _TemplateMetaclass.pattern % {
Barry Warsaw17cb6002004-09-18 00:06:34 +0000118 'delim' : _re.escape(cls.delimiter),
Barry Warsaw12827c12004-09-10 03:08:08 +0000119 'id' : cls.idpattern,
120 }
121 cls.pattern = _re.compile(pattern, _re.IGNORECASE | _re.VERBOSE)
122
123
124class Template:
Barry Warsaw8bee7612004-08-25 02:22:30 +0000125 """A string class for supporting $-substitutions."""
Barry Warsaw12827c12004-09-10 03:08:08 +0000126 __metaclass__ = _TemplateMetaclass
127
Barry Warsaw17cb6002004-09-18 00:06:34 +0000128 delimiter = '$'
Barry Warsaw12827c12004-09-10 03:08:08 +0000129 idpattern = r'[_a-z][_a-z0-9]*'
130
131 def __init__(self, template):
132 self.template = template
Barry Warsaw8bee7612004-08-25 02:22:30 +0000133
134 # Search for $$, $identifier, ${identifier}, and any bare $'s
Barry Warsaw8bee7612004-08-25 02:22:30 +0000135
Barry Warsawb5c6b5b2004-09-13 20:52:50 +0000136 def _invalid(self, mo):
137 i = mo.start('invalid')
Barry Warsaw12827c12004-09-10 03:08:08 +0000138 lines = self.template[:i].splitlines(True)
139 if not lines:
140 colno = 1
141 lineno = 1
142 else:
143 colno = i - len(''.join(lines[:-1]))
144 lineno = len(lines)
145 raise ValueError('Invalid placeholder in string: line %d, col %d' %
146 (lineno, colno))
147
Serhiy Storchaka40fd0e82015-03-24 22:27:50 +0200148 def substitute(*args, **kws):
149 if not args:
150 raise TypeError("descriptor 'substitute' of 'Template' object "
151 "needs an argument")
152 self, args = args[0], args[1:] # allow the "self" keyword be passed
Barry Warsawb6234a92004-09-13 15:25:15 +0000153 if len(args) > 1:
154 raise TypeError('Too many positional arguments')
155 if not args:
156 mapping = kws
Barry Warsaw46b629c2004-09-13 14:35:04 +0000157 elif kws:
Barry Warsawb6234a92004-09-13 15:25:15 +0000158 mapping = _multimap(kws, args[0])
159 else:
160 mapping = args[0]
Barry Warsaw46b629c2004-09-13 14:35:04 +0000161 # Helper function for .sub()
Barry Warsaw8bee7612004-08-25 02:22:30 +0000162 def convert(mo):
Barry Warsawb5c6b5b2004-09-13 20:52:50 +0000163 # Check the most common path first.
164 named = mo.group('named') or mo.group('braced')
165 if named is not None:
166 val = mapping[named]
167 # We use this idiom instead of str() because the latter will
168 # fail if val is a Unicode containing non-ASCII characters.
Thomas Woutersadd19112006-07-05 11:03:49 +0000169 return '%s' % (val,)
Raymond Hettinger0d58e2b2004-08-26 00:21:13 +0000170 if mo.group('escaped') is not None:
Barry Warsaw17cb6002004-09-18 00:06:34 +0000171 return self.delimiter
Barry Warsawb5c6b5b2004-09-13 20:52:50 +0000172 if mo.group('invalid') is not None:
173 self._invalid(mo)
Neal Norwitz6627a962004-10-17 16:27:18 +0000174 raise ValueError('Unrecognized named group in pattern',
175 self.pattern)
Barry Warsaw12827c12004-09-10 03:08:08 +0000176 return self.pattern.sub(convert, self.template)
Barry Warsaw8bee7612004-08-25 02:22:30 +0000177
Serhiy Storchaka40fd0e82015-03-24 22:27:50 +0200178 def safe_substitute(*args, **kws):
179 if not args:
180 raise TypeError("descriptor 'safe_substitute' of 'Template' object "
181 "needs an argument")
182 self, args = args[0], args[1:] # allow the "self" keyword be passed
Barry Warsawb6234a92004-09-13 15:25:15 +0000183 if len(args) > 1:
184 raise TypeError('Too many positional arguments')
185 if not args:
186 mapping = kws
Barry Warsaw46b629c2004-09-13 14:35:04 +0000187 elif kws:
Barry Warsawb6234a92004-09-13 15:25:15 +0000188 mapping = _multimap(kws, args[0])
189 else:
190 mapping = args[0]
Barry Warsaw46b629c2004-09-13 14:35:04 +0000191 # Helper function for .sub()
Barry Warsaw8bee7612004-08-25 02:22:30 +0000192 def convert(mo):
Florent Xiclunaff05e522010-09-18 23:34:07 +0000193 named = mo.group('named') or mo.group('braced')
Barry Warsaw8bee7612004-08-25 02:22:30 +0000194 if named is not None:
195 try:
Barry Warsaw12827c12004-09-10 03:08:08 +0000196 # We use this idiom instead of str() because the latter
197 # will fail if val is a Unicode containing non-ASCII
Thomas Woutersadd19112006-07-05 11:03:49 +0000198 return '%s' % (mapping[named],)
Barry Warsaw8bee7612004-08-25 02:22:30 +0000199 except KeyError:
Florent Xiclunaff05e522010-09-18 23:34:07 +0000200 return mo.group()
Barry Warsawb5c6b5b2004-09-13 20:52:50 +0000201 if mo.group('escaped') is not None:
Barry Warsaw17cb6002004-09-18 00:06:34 +0000202 return self.delimiter
Barry Warsawb5c6b5b2004-09-13 20:52:50 +0000203 if mo.group('invalid') is not None:
Florent Xiclunaff05e522010-09-18 23:34:07 +0000204 return mo.group()
Neal Norwitz6627a962004-10-17 16:27:18 +0000205 raise ValueError('Unrecognized named group in pattern',
206 self.pattern)
Barry Warsaw12827c12004-09-10 03:08:08 +0000207 return self.pattern.sub(convert, self.template)
Barry Warsaw8bee7612004-08-25 02:22:30 +0000208
209
Raymond Hettinger57aef9c2004-12-07 07:55:07 +0000210
Raymond Hettinger0d58e2b2004-08-26 00:21:13 +0000211####################################################################
Barry Warsaw8bee7612004-08-25 02:22:30 +0000212# NOTE: Everything below here is deprecated. Use string methods instead.
213# This stuff will go away in Python 3.0.
214
Guido van Rossum710c3521994-08-17 13:16:11 +0000215# Backward compatible names for exceptions
216index_error = ValueError
217atoi_error = ValueError
218atof_error = ValueError
219atol_error = ValueError
220
Guido van Rossumc6360141990-10-13 19:23:40 +0000221# convert UPPER CASE letters to lower case
222def lower(s):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000223 """lower(s) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000224
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000225 Return a copy of the string s converted to lowercase.
Guido van Rossum20032041997-12-29 19:26:28 +0000226
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000227 """
228 return s.lower()
Guido van Rossumc6360141990-10-13 19:23:40 +0000229
230# Convert lower case letters to UPPER CASE
231def upper(s):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000232 """upper(s) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000233
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000234 Return a copy of the string s converted to uppercase.
Guido van Rossum20032041997-12-29 19:26:28 +0000235
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000236 """
237 return s.upper()
Guido van Rossumc6360141990-10-13 19:23:40 +0000238
239# Swap lower case letters and UPPER CASE
240def swapcase(s):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000241 """swapcase(s) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000242
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000243 Return a copy of the string s with upper case characters
244 converted to lowercase and vice versa.
Guido van Rossum20032041997-12-29 19:26:28 +0000245
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000246 """
247 return s.swapcase()
Guido van Rossumc6360141990-10-13 19:23:40 +0000248
249# Strip leading and trailing tabs and spaces
Martin v. Löwis1f046102002-11-08 12:09:59 +0000250def strip(s, chars=None):
Neal Norwitza4864a22002-11-14 03:31:32 +0000251 """strip(s [,chars]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000252
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000253 Return a copy of the string s with leading and trailing
254 whitespace removed.
Neal Norwitzffe33b72003-04-10 22:35:32 +0000255 If chars is given and not None, remove characters in chars instead.
Neal Norwitza4864a22002-11-14 03:31:32 +0000256 If chars is unicode, S will be converted to unicode before stripping.
Guido van Rossum20032041997-12-29 19:26:28 +0000257
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000258 """
Martin v. Löwis1f046102002-11-08 12:09:59 +0000259 return s.strip(chars)
Guido van Rossumc6360141990-10-13 19:23:40 +0000260
Guido van Rossum306a8a61996-08-08 18:40:59 +0000261# Strip leading tabs and spaces
Neal Norwitzffe33b72003-04-10 22:35:32 +0000262def lstrip(s, chars=None):
263 """lstrip(s [,chars]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000264
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000265 Return a copy of the string s with leading whitespace removed.
Neal Norwitzffe33b72003-04-10 22:35:32 +0000266 If chars is given and not None, remove characters in chars instead.
Guido van Rossum20032041997-12-29 19:26:28 +0000267
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000268 """
Neal Norwitzffe33b72003-04-10 22:35:32 +0000269 return s.lstrip(chars)
Guido van Rossum306a8a61996-08-08 18:40:59 +0000270
271# Strip trailing tabs and spaces
Neal Norwitzffe33b72003-04-10 22:35:32 +0000272def rstrip(s, chars=None):
273 """rstrip(s [,chars]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000274
Neal Norwitzffe33b72003-04-10 22:35:32 +0000275 Return a copy of the string s with trailing whitespace removed.
276 If chars is given and not None, remove characters in chars instead.
Guido van Rossum20032041997-12-29 19:26:28 +0000277
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000278 """
Neal Norwitzffe33b72003-04-10 22:35:32 +0000279 return s.rstrip(chars)
Guido van Rossum306a8a61996-08-08 18:40:59 +0000280
281
Guido van Rossumc6360141990-10-13 19:23:40 +0000282# Split a string into a list of space/tab-separated words
Guido van Rossum8f0c5a72000-03-10 23:22:10 +0000283def split(s, sep=None, maxsplit=-1):
Fred Drakee4f13661999-11-04 19:19:48 +0000284 """split(s [,sep [,maxsplit]]) -> list of strings
Guido van Rossum20032041997-12-29 19:26:28 +0000285
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000286 Return a list of the words in the string s, using sep as the
Fred Drake14537542002-01-30 16:15:13 +0000287 delimiter string. If maxsplit is given, splits at no more than
288 maxsplit places (resulting in at most maxsplit+1 words). If sep
Walter Dörwald065a32f2004-09-14 09:45:10 +0000289 is not specified or is None, any whitespace string is a separator.
Guido van Rossum20032041997-12-29 19:26:28 +0000290
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000291 (split and splitfields are synonymous)
Guido van Rossum20032041997-12-29 19:26:28 +0000292
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000293 """
294 return s.split(sep, maxsplit)
295splitfields = split
Guido van Rossumfac38b71991-04-07 13:42:19 +0000296
Hye-Shik Chang3ae811b2003-12-15 18:49:53 +0000297# Split a string into a list of space/tab-separated words
298def rsplit(s, sep=None, maxsplit=-1):
299 """rsplit(s [,sep [,maxsplit]]) -> list of strings
300
301 Return a list of the words in the string s, using sep as the
302 delimiter string, starting at the end of the string and working
303 to the front. If maxsplit is given, at most maxsplit splits are
304 done. If sep is not specified or is None, any whitespace string
305 is a separator.
306 """
307 return s.rsplit(sep, maxsplit)
308
Guido van Rossum2ab19921995-06-22 18:58:00 +0000309# Join fields with optional separator
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000310def join(words, sep = ' '):
311 """join(list [,sep]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000312
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000313 Return a string composed of the words in list, with
Thomas Wouters7e474022000-07-16 12:04:32 +0000314 intervening occurrences of sep. The default separator is a
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000315 single space.
Guido van Rossum20032041997-12-29 19:26:28 +0000316
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000317 (joinfields and join are synonymous)
Guido van Rossum20032041997-12-29 19:26:28 +0000318
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000319 """
320 return sep.join(words)
321joinfields = join
322
Guido van Rossumd3166071993-05-24 14:16:22 +0000323# Find substring, raise exception if not found
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000324def index(s, *args):
325 """index(s, sub [,start [,end]]) -> int
Guido van Rossum20032041997-12-29 19:26:28 +0000326
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000327 Like find but raises ValueError when the substring is not found.
Guido van Rossum20032041997-12-29 19:26:28 +0000328
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000329 """
Fred Drake046d2722000-07-03 07:23:13 +0000330 return s.index(*args)
Guido van Rossumd3166071993-05-24 14:16:22 +0000331
Guido van Rossume65cce51993-11-08 15:05:21 +0000332# Find last substring, raise exception if not found
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000333def rindex(s, *args):
334 """rindex(s, sub [,start [,end]]) -> int
Guido van Rossum20032041997-12-29 19:26:28 +0000335
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000336 Like rfind but raises ValueError when the substring is not found.
Guido van Rossum20032041997-12-29 19:26:28 +0000337
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000338 """
Fred Drake046d2722000-07-03 07:23:13 +0000339 return s.rindex(*args)
Guido van Rossumb6775db1994-08-01 11:34:53 +0000340
341# Count non-overlapping occurrences of substring
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000342def count(s, *args):
343 """count(s, sub[, start[,end]]) -> int
Guido van Rossum20032041997-12-29 19:26:28 +0000344
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000345 Return the number of occurrences of substring sub in string
346 s[start:end]. Optional arguments start and end are
347 interpreted as in slice notation.
Guido van Rossum20032041997-12-29 19:26:28 +0000348
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000349 """
Fred Drake046d2722000-07-03 07:23:13 +0000350 return s.count(*args)
Guido van Rossume65cce51993-11-08 15:05:21 +0000351
Guido van Rossumd3166071993-05-24 14:16:22 +0000352# Find substring, return -1 if not found
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000353def find(s, *args):
354 """find(s, sub [,start [,end]]) -> in
Guido van Rossum20032041997-12-29 19:26:28 +0000355
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000356 Return the lowest index in s where substring sub is found,
357 such that sub is contained within s[start,end]. Optional
358 arguments start and end are interpreted as in slice notation.
Guido van Rossum20032041997-12-29 19:26:28 +0000359
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000360 Return -1 on failure.
Guido van Rossum20032041997-12-29 19:26:28 +0000361
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000362 """
Fred Drake046d2722000-07-03 07:23:13 +0000363 return s.find(*args)
Guido van Rossumc6360141990-10-13 19:23:40 +0000364
Guido van Rossume65cce51993-11-08 15:05:21 +0000365# Find last substring, return -1 if not found
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000366def rfind(s, *args):
367 """rfind(s, sub [,start [,end]]) -> int
Guido van Rossum20032041997-12-29 19:26:28 +0000368
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000369 Return the highest index in s where substring sub is found,
370 such that sub is contained within s[start,end]. Optional
371 arguments start and end are interpreted as in slice notation.
Guido van Rossum20032041997-12-29 19:26:28 +0000372
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000373 Return -1 on failure.
Guido van Rossum20032041997-12-29 19:26:28 +0000374
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000375 """
Fred Drake046d2722000-07-03 07:23:13 +0000376 return s.rfind(*args)
Guido van Rossume65cce51993-11-08 15:05:21 +0000377
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000378# for a bit of speed
379_float = float
380_int = int
381_long = long
Guido van Rossumd0753e21997-12-10 22:59:55 +0000382
Guido van Rossume61fa0a1993-10-22 13:56:35 +0000383# Convert string to float
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000384def atof(s):
385 """atof(s) -> float
Guido van Rossum20032041997-12-29 19:26:28 +0000386
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000387 Return the floating point number represented by the string s.
Guido van Rossum20032041997-12-29 19:26:28 +0000388
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000389 """
Guido van Rossum9e896b32000-04-05 20:11:21 +0000390 return _float(s)
391
Guido van Rossume61fa0a1993-10-22 13:56:35 +0000392
Guido van Rossumc6360141990-10-13 19:23:40 +0000393# Convert string to integer
Guido van Rossum9e896b32000-04-05 20:11:21 +0000394def atoi(s , base=10):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000395 """atoi(s [,base]) -> int
Guido van Rossum20032041997-12-29 19:26:28 +0000396
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000397 Return the integer represented by the string s in the given
398 base, which defaults to 10. The string s must consist of one
399 or more digits, possibly preceded by a sign. If base is 0, it
400 is chosen from the leading characters of s, 0 for octal, 0x or
401 0X for hexadecimal. If base is 16, a preceding 0x or 0X is
402 accepted.
Guido van Rossum20032041997-12-29 19:26:28 +0000403
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000404 """
Guido van Rossum9e896b32000-04-05 20:11:21 +0000405 return _int(s, base)
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000406
Guido van Rossumc6360141990-10-13 19:23:40 +0000407
Guido van Rossume61fa0a1993-10-22 13:56:35 +0000408# Convert string to long integer
Guido van Rossum9e896b32000-04-05 20:11:21 +0000409def atol(s, base=10):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000410 """atol(s [,base]) -> long
Guido van Rossum20032041997-12-29 19:26:28 +0000411
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000412 Return the long integer represented by the string s in the
413 given base, which defaults to 10. The string s must consist
414 of one or more digits, possibly preceded by a sign. If base
415 is 0, it is chosen from the leading characters of s, 0 for
416 octal, 0x or 0X for hexadecimal. If base is 16, a preceding
417 0x or 0X is accepted. A trailing L or l is not accepted,
418 unless base is 0.
Guido van Rossum20032041997-12-29 19:26:28 +0000419
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000420 """
Guido van Rossum9e896b32000-04-05 20:11:21 +0000421 return _long(s, base)
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000422
Guido van Rossume61fa0a1993-10-22 13:56:35 +0000423
Guido van Rossumc6360141990-10-13 19:23:40 +0000424# Left-justify a string
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000425def ljust(s, width, *args):
426 """ljust(s, width[, fillchar]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000427
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000428 Return a left-justified version of s, in a field of the
429 specified width, padded with spaces as needed. The string is
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000430 never truncated. If specified the fillchar is used instead of spaces.
Guido van Rossum20032041997-12-29 19:26:28 +0000431
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000432 """
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000433 return s.ljust(width, *args)
Guido van Rossumc6360141990-10-13 19:23:40 +0000434
435# Right-justify a string
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000436def rjust(s, width, *args):
437 """rjust(s, width[, fillchar]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000438
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000439 Return a right-justified version of s, in a field of the
440 specified width, padded with spaces as needed. The string is
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000441 never truncated. If specified the fillchar is used instead of spaces.
Guido van Rossum20032041997-12-29 19:26:28 +0000442
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000443 """
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000444 return s.rjust(width, *args)
Guido van Rossumc6360141990-10-13 19:23:40 +0000445
446# Center a string
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000447def center(s, width, *args):
448 """center(s, width[, fillchar]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000449
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000450 Return a center version of s, in a field of the specified
451 width. padded with spaces as needed. The string is never
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000452 truncated. If specified the fillchar is used instead of spaces.
Guido van Rossum20032041997-12-29 19:26:28 +0000453
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000454 """
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000455 return s.center(width, *args)
Guido van Rossumc6360141990-10-13 19:23:40 +0000456
457# Zero-fill a number, e.g., (12, 3) --> '012' and (-3, 3) --> '-03'
458# Decadent feature: the argument may be a string or a number
459# (Use of this is deprecated; it should be a string as with ljust c.s.)
460def zfill(x, width):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000461 """zfill(x, width) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000462
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000463 Pad a numeric string x with zeros on the left, to fill a field
464 of the specified width. The string x is never truncated.
Guido van Rossum20032041997-12-29 19:26:28 +0000465
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000466 """
Walter Dörwald65230a22002-06-03 15:58:32 +0000467 if not isinstance(x, basestring):
Walter Dörwald068325e2002-04-15 13:36:47 +0000468 x = repr(x)
469 return x.zfill(width)
Guido van Rossum6ff2e901992-03-27 15:13:31 +0000470
471# Expand tabs in a string.
472# Doesn't take non-printing chars into account, but does understand \n.
Guido van Rossum894a7bb1995-08-10 19:42:05 +0000473def expandtabs(s, tabsize=8):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000474 """expandtabs(s [,tabsize]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000475
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000476 Return a copy of the string s with all tab characters replaced
477 by the appropriate number of spaces, depending on the current
478 column, and the tabsize (default 8).
Guido van Rossum20032041997-12-29 19:26:28 +0000479
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000480 """
Fred Drake046d2722000-07-03 07:23:13 +0000481 return s.expandtabs(tabsize)
Guido van Rossum2db91351992-10-18 17:09:59 +0000482
Guido van Rossum25395281996-05-28 23:08:45 +0000483# Character translation through look-up table.
Guido van Rossumed7253c1996-07-23 18:12:39 +0000484def translate(s, table, deletions=""):
Guido van Rossum5aff7752000-12-19 02:39:08 +0000485 """translate(s,table [,deletions]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000486
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000487 Return a copy of the string s, where all characters occurring
Guido van Rossum5aff7752000-12-19 02:39:08 +0000488 in the optional argument deletions are removed, and the
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000489 remaining characters have been mapped through the given
Guido van Rossum5aff7752000-12-19 02:39:08 +0000490 translation table, which must be a string of length 256. The
491 deletions argument is not allowed for Unicode strings.
Guido van Rossum20032041997-12-29 19:26:28 +0000492
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000493 """
Raymond Hettinger4db5fe92007-04-12 04:10:00 +0000494 if deletions or table is None:
Guido van Rossum5aff7752000-12-19 02:39:08 +0000495 return s.translate(table, deletions)
496 else:
497 # Add s[:0] so that if s is Unicode and table is an 8-bit string,
498 # table is converted to Unicode. This means that table *cannot*
499 # be a dictionary -- for that feature, use u.translate() directly.
500 return s.translate(table + s[:0])
Guido van Rossum2db91351992-10-18 17:09:59 +0000501
Guido van Rossum8775d8b1996-06-11 18:43:00 +0000502# Capitalize a string, e.g. "aBc dEf" -> "Abc def".
503def capitalize(s):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000504 """capitalize(s) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000505
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000506 Return a copy of the string s with only its first character
507 capitalized.
Guido van Rossum20032041997-12-29 19:26:28 +0000508
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000509 """
510 return s.capitalize()
Guido van Rossum8775d8b1996-06-11 18:43:00 +0000511
Guido van Rossum1eb9a811997-03-25 16:50:31 +0000512# Substring replacement (global)
Senthil Kumarana240cb12010-09-08 12:40:45 +0000513def replace(s, old, new, maxreplace=-1):
514 """replace (str, old, new[, maxreplace]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000515
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000516 Return a copy of string str with all occurrences of substring
Senthil Kumarana240cb12010-09-08 12:40:45 +0000517 old replaced by new. If the optional argument maxreplace is
518 given, only the first maxreplace occurrences are replaced.
Guido van Rossum20032041997-12-29 19:26:28 +0000519
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000520 """
Senthil Kumarana240cb12010-09-08 12:40:45 +0000521 return s.replace(old, new, maxreplace)
Guido van Rossum1eb9a811997-03-25 16:50:31 +0000522
523
Guido van Rossum2db91351992-10-18 17:09:59 +0000524# Try importing optional built-in module "strop" -- if it exists,
525# it redefines some string operations that are 100-1000 times faster.
Guido van Rossum8e2ec561993-07-29 09:37:38 +0000526# It also defines values for whitespace, lowercase and uppercase
527# that match <ctype.h>'s definitions.
Guido van Rossum2db91351992-10-18 17:09:59 +0000528
529try:
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000530 from strop import maketrans, lowercase, uppercase, whitespace
531 letters = lowercase + uppercase
Guido van Rossumb6775db1994-08-01 11:34:53 +0000532except ImportError:
Fred Drake857c4c32000-02-10 16:21:11 +0000533 pass # Use the original versions
Eric Smitha9f7d622008-02-17 19:46:49 +0000534
535########################################################################
536# the Formatter class
537# see PEP 3101 for details and purpose of this class
538
Benjamin Petersonb7c95ce2008-11-09 01:52:32 +0000539# The hard parts are reused from the C implementation. They're exposed as "_"
540# prefixed methods of str and unicode.
Eric Smitha9f7d622008-02-17 19:46:49 +0000541
542# The overall parser is implemented in str._formatter_parser.
543# The field name parser is implemented in str._formatter_field_name_split
544
545class Formatter(object):
Serhiy Storchaka40fd0e82015-03-24 22:27:50 +0200546 def format(*args, **kwargs):
547 if not args:
548 raise TypeError("descriptor 'format' of 'Formatter' object "
549 "needs an argument")
550 self, args = args[0], args[1:] # allow the "self" keyword be passed
551 try:
552 format_string, args = args[0], args[1:] # allow the "format_string" keyword be passed
553 except IndexError:
554 if 'format_string' in kwargs:
555 format_string = kwargs.pop('format_string')
556 else:
557 raise TypeError("format() missing 1 required positional "
558 "argument: 'format_string'")
Eric Smitha9f7d622008-02-17 19:46:49 +0000559 return self.vformat(format_string, args, kwargs)
560
561 def vformat(self, format_string, args, kwargs):
562 used_args = set()
563 result = self._vformat(format_string, args, kwargs, used_args, 2)
564 self.check_unused_args(used_args, args, kwargs)
565 return result
566
567 def _vformat(self, format_string, args, kwargs, used_args, recursion_depth):
568 if recursion_depth < 0:
569 raise ValueError('Max string recursion exceeded')
570 result = []
571 for literal_text, field_name, format_spec, conversion in \
572 self.parse(format_string):
573
574 # output the literal text
575 if literal_text:
576 result.append(literal_text)
577
578 # if there's a field, output it
579 if field_name is not None:
580 # this is some markup, find the object and do
581 # the formatting
582
583 # given the field_name, find the object it references
584 # and the argument it came from
585 obj, arg_used = self.get_field(field_name, args, kwargs)
586 used_args.add(arg_used)
587
588 # do any conversion on the resulting object
589 obj = self.convert_field(obj, conversion)
590
591 # expand the format spec, if needed
592 format_spec = self._vformat(format_spec, args, kwargs,
593 used_args, recursion_depth-1)
594
595 # format the object and append to the result
596 result.append(self.format_field(obj, format_spec))
597
598 return ''.join(result)
599
600
601 def get_value(self, key, args, kwargs):
602 if isinstance(key, (int, long)):
603 return args[key]
604 else:
605 return kwargs[key]
606
607
608 def check_unused_args(self, used_args, args, kwargs):
609 pass
610
611
612 def format_field(self, value, format_spec):
613 return format(value, format_spec)
614
615
616 def convert_field(self, value, conversion):
617 # do any conversion on the resulting object
R David Murrayd928b6a2012-08-19 17:57:29 -0400618 if conversion is None:
619 return value
Eric Smitha9f7d622008-02-17 19:46:49 +0000620 elif conversion == 's':
621 return str(value)
R David Murrayd928b6a2012-08-19 17:57:29 -0400622 elif conversion == 'r':
623 return repr(value)
Florent Xicluna9b90cd12010-09-13 07:46:37 +0000624 raise ValueError("Unknown conversion specifier {0!s}".format(conversion))
Eric Smitha9f7d622008-02-17 19:46:49 +0000625
626
627 # returns an iterable that contains tuples of the form:
628 # (literal_text, field_name, format_spec, conversion)
629 # literal_text can be zero length
630 # field_name can be None, in which case there's no
631 # object to format and output
632 # if field_name is not None, it is looked up, formatted
633 # with format_spec and conversion and then used
634 def parse(self, format_string):
635 return format_string._formatter_parser()
636
637
638 # given a field_name, find the object it references.
639 # field_name: the field being looked up, e.g. "0.name"
640 # or "lookup[3]"
641 # used_args: a set of which args have been used
642 # args, kwargs: as passed in to vformat
643 def get_field(self, field_name, args, kwargs):
644 first, rest = field_name._formatter_field_name_split()
645
646 obj = self.get_value(first, args, kwargs)
647
648 # loop through the rest of the field_name, doing
649 # getattr or getitem as needed
650 for is_attr, i in rest:
651 if is_attr:
652 obj = getattr(obj, i)
653 else:
654 obj = obj[i]
655
656 return obj, first