blob: 623eb0edab89667edd7fff5b929bb3334542f7d8 [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
Barry Warsaw8bee7612004-08-25 02:22:30 +000038# Note that Cookie.py bogusly uses _idmap :(
Martin v. Löwis5357c652002-10-14 20:03:40 +000039l = map(chr, xrange(256))
40_idmap = str('').join(l)
41del l
Guido van Rossumc6360141990-10-13 19:23:40 +000042
Barry Warsaw8bee7612004-08-25 02:22:30 +000043# Functions which aren't available as string methods.
44
45# Capitalize the words in a string, e.g. " aBc dEf " -> "Abc Def".
46# See also regsub.capwords().
47def capwords(s, sep=None):
48 """capwords(s, [sep]) -> string
49
50 Split the argument into words using split, capitalize each
51 word using capitalize, and join the capitalized words using
52 join. Note that this replaces runs of whitespace characters by
53 a single space.
54
55 """
56 return (sep or ' ').join([x.capitalize() for x in s.split(sep)])
57
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:
73 _idmapL = map(None, _idmap)
74 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
81
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"""
104 (?P<escaped>%(delim)s{2}) | # Escape sequence of two delimiters
105 %(delim)s(?P<named>%(id)s) | # delimiter and a Python identifier
106 %(delim)s{(?P<braced>%(id)s)} | # delimiter and a braced identifier
Barry Warsawb5c6b5b2004-09-13 20:52:50 +0000107 (?P<invalid>%(delim)s) # Other ill-formed delimiter exprs
Barry Warsaw12827c12004-09-10 03:08:08 +0000108 """
109
110 def __init__(cls, name, bases, dct):
111 super(_TemplateMetaclass, cls).__init__(name, bases, dct)
112 if 'pattern' in dct:
113 pattern = cls.pattern
114 else:
115 pattern = _TemplateMetaclass.pattern % {
Barry Warsaw17cb6002004-09-18 00:06:34 +0000116 'delim' : _re.escape(cls.delimiter),
Barry Warsaw12827c12004-09-10 03:08:08 +0000117 'id' : cls.idpattern,
118 }
119 cls.pattern = _re.compile(pattern, _re.IGNORECASE | _re.VERBOSE)
120
121
122class Template:
Barry Warsaw8bee7612004-08-25 02:22:30 +0000123 """A string class for supporting $-substitutions."""
Barry Warsaw12827c12004-09-10 03:08:08 +0000124 __metaclass__ = _TemplateMetaclass
125
Barry Warsaw17cb6002004-09-18 00:06:34 +0000126 delimiter = '$'
Barry Warsaw12827c12004-09-10 03:08:08 +0000127 idpattern = r'[_a-z][_a-z0-9]*'
128
129 def __init__(self, template):
130 self.template = template
Barry Warsaw8bee7612004-08-25 02:22:30 +0000131
132 # Search for $$, $identifier, ${identifier}, and any bare $'s
Barry Warsaw8bee7612004-08-25 02:22:30 +0000133
Barry Warsawb5c6b5b2004-09-13 20:52:50 +0000134 def _invalid(self, mo):
135 i = mo.start('invalid')
Barry Warsaw12827c12004-09-10 03:08:08 +0000136 lines = self.template[:i].splitlines(True)
137 if not lines:
138 colno = 1
139 lineno = 1
140 else:
141 colno = i - len(''.join(lines[:-1]))
142 lineno = len(lines)
143 raise ValueError('Invalid placeholder in string: line %d, col %d' %
144 (lineno, colno))
145
Barry Warsawb6234a92004-09-13 15:25:15 +0000146 def substitute(self, *args, **kws):
147 if len(args) > 1:
148 raise TypeError('Too many positional arguments')
149 if not args:
150 mapping = kws
Barry Warsaw46b629c2004-09-13 14:35:04 +0000151 elif kws:
Barry Warsawb6234a92004-09-13 15:25:15 +0000152 mapping = _multimap(kws, args[0])
153 else:
154 mapping = args[0]
Barry Warsaw46b629c2004-09-13 14:35:04 +0000155 # Helper function for .sub()
Barry Warsaw8bee7612004-08-25 02:22:30 +0000156 def convert(mo):
Barry Warsawb5c6b5b2004-09-13 20:52:50 +0000157 # Check the most common path first.
158 named = mo.group('named') or mo.group('braced')
159 if named is not None:
160 val = mapping[named]
161 # We use this idiom instead of str() because the latter will
162 # fail if val is a Unicode containing non-ASCII characters.
163 return '%s' % val
Raymond Hettinger0d58e2b2004-08-26 00:21:13 +0000164 if mo.group('escaped') is not None:
Barry Warsaw17cb6002004-09-18 00:06:34 +0000165 return self.delimiter
Barry Warsawb5c6b5b2004-09-13 20:52:50 +0000166 if mo.group('invalid') is not None:
167 self._invalid(mo)
Raymond Hettinger6d191112004-09-14 02:34:08 +0000168 raise ValueError('Unrecognized named group in pattern', pattern)
Barry Warsaw12827c12004-09-10 03:08:08 +0000169 return self.pattern.sub(convert, self.template)
Barry Warsaw8bee7612004-08-25 02:22:30 +0000170
Barry Warsawb6234a92004-09-13 15:25:15 +0000171 def safe_substitute(self, *args, **kws):
172 if len(args) > 1:
173 raise TypeError('Too many positional arguments')
174 if not args:
175 mapping = kws
Barry Warsaw46b629c2004-09-13 14:35:04 +0000176 elif kws:
Barry Warsawb6234a92004-09-13 15:25:15 +0000177 mapping = _multimap(kws, args[0])
178 else:
179 mapping = args[0]
Barry Warsaw46b629c2004-09-13 14:35:04 +0000180 # Helper function for .sub()
Barry Warsaw8bee7612004-08-25 02:22:30 +0000181 def convert(mo):
Raymond Hettinger0d58e2b2004-08-26 00:21:13 +0000182 named = mo.group('named')
Barry Warsaw8bee7612004-08-25 02:22:30 +0000183 if named is not None:
184 try:
Barry Warsaw12827c12004-09-10 03:08:08 +0000185 # We use this idiom instead of str() because the latter
186 # will fail if val is a Unicode containing non-ASCII
Barry Warsawb6234a92004-09-13 15:25:15 +0000187 return '%s' % mapping[named]
Barry Warsaw8bee7612004-08-25 02:22:30 +0000188 except KeyError:
Barry Warsaw17cb6002004-09-18 00:06:34 +0000189 return self.delimiter + named
Raymond Hettinger0d58e2b2004-08-26 00:21:13 +0000190 braced = mo.group('braced')
Raymond Hettinger6d191112004-09-14 02:34:08 +0000191 if braced is not None:
192 try:
193 return '%s' % mapping[braced]
194 except KeyError:
Barry Warsaw17cb6002004-09-18 00:06:34 +0000195 return self.delimiter + '{' + braced + '}'
Barry Warsawb5c6b5b2004-09-13 20:52:50 +0000196 if mo.group('escaped') is not None:
Barry Warsaw17cb6002004-09-18 00:06:34 +0000197 return self.delimiter
Barry Warsawb5c6b5b2004-09-13 20:52:50 +0000198 if mo.group('invalid') is not None:
199 self._invalid(mo)
Raymond Hettinger6d191112004-09-14 02:34:08 +0000200 raise ValueError('Unrecognized named group in pattern', pattern)
Barry Warsaw12827c12004-09-10 03:08:08 +0000201 return self.pattern.sub(convert, self.template)
Barry Warsaw8bee7612004-08-25 02:22:30 +0000202
203
204
Raymond Hettinger0d58e2b2004-08-26 00:21:13 +0000205####################################################################
Barry Warsaw8bee7612004-08-25 02:22:30 +0000206# NOTE: Everything below here is deprecated. Use string methods instead.
207# This stuff will go away in Python 3.0.
208
Guido van Rossum710c3521994-08-17 13:16:11 +0000209# Backward compatible names for exceptions
210index_error = ValueError
211atoi_error = ValueError
212atof_error = ValueError
213atol_error = ValueError
214
Guido van Rossumc6360141990-10-13 19:23:40 +0000215# convert UPPER CASE letters to lower case
216def lower(s):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000217 """lower(s) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000218
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000219 Return a copy of the string s converted to lowercase.
Guido van Rossum20032041997-12-29 19:26:28 +0000220
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000221 """
222 return s.lower()
Guido van Rossumc6360141990-10-13 19:23:40 +0000223
224# Convert lower case letters to UPPER CASE
225def upper(s):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000226 """upper(s) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000227
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000228 Return a copy of the string s converted to uppercase.
Guido van Rossum20032041997-12-29 19:26:28 +0000229
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000230 """
231 return s.upper()
Guido van Rossumc6360141990-10-13 19:23:40 +0000232
233# Swap lower case letters and UPPER CASE
234def swapcase(s):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000235 """swapcase(s) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000236
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000237 Return a copy of the string s with upper case characters
238 converted to lowercase and vice versa.
Guido van Rossum20032041997-12-29 19:26:28 +0000239
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000240 """
241 return s.swapcase()
Guido van Rossumc6360141990-10-13 19:23:40 +0000242
243# Strip leading and trailing tabs and spaces
Martin v. Löwis1f046102002-11-08 12:09:59 +0000244def strip(s, chars=None):
Neal Norwitza4864a22002-11-14 03:31:32 +0000245 """strip(s [,chars]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000246
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000247 Return a copy of the string s with leading and trailing
248 whitespace removed.
Neal Norwitzffe33b72003-04-10 22:35:32 +0000249 If chars is given and not None, remove characters in chars instead.
Neal Norwitza4864a22002-11-14 03:31:32 +0000250 If chars is unicode, S will be converted to unicode before stripping.
Guido van Rossum20032041997-12-29 19:26:28 +0000251
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000252 """
Martin v. Löwis1f046102002-11-08 12:09:59 +0000253 return s.strip(chars)
Guido van Rossumc6360141990-10-13 19:23:40 +0000254
Guido van Rossum306a8a61996-08-08 18:40:59 +0000255# Strip leading tabs and spaces
Neal Norwitzffe33b72003-04-10 22:35:32 +0000256def lstrip(s, chars=None):
257 """lstrip(s [,chars]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000258
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000259 Return a copy of the string s with leading whitespace removed.
Neal Norwitzffe33b72003-04-10 22:35:32 +0000260 If chars is given and not None, remove characters in chars instead.
Guido van Rossum20032041997-12-29 19:26:28 +0000261
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000262 """
Neal Norwitzffe33b72003-04-10 22:35:32 +0000263 return s.lstrip(chars)
Guido van Rossum306a8a61996-08-08 18:40:59 +0000264
265# Strip trailing tabs and spaces
Neal Norwitzffe33b72003-04-10 22:35:32 +0000266def rstrip(s, chars=None):
267 """rstrip(s [,chars]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000268
Neal Norwitzffe33b72003-04-10 22:35:32 +0000269 Return a copy of the string s with trailing whitespace removed.
270 If chars is given and not None, remove characters in chars instead.
Guido van Rossum20032041997-12-29 19:26:28 +0000271
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000272 """
Neal Norwitzffe33b72003-04-10 22:35:32 +0000273 return s.rstrip(chars)
Guido van Rossum306a8a61996-08-08 18:40:59 +0000274
275
Guido van Rossumc6360141990-10-13 19:23:40 +0000276# Split a string into a list of space/tab-separated words
Guido van Rossum8f0c5a72000-03-10 23:22:10 +0000277def split(s, sep=None, maxsplit=-1):
Fred Drakee4f13661999-11-04 19:19:48 +0000278 """split(s [,sep [,maxsplit]]) -> list of strings
Guido van Rossum20032041997-12-29 19:26:28 +0000279
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000280 Return a list of the words in the string s, using sep as the
Fred Drake14537542002-01-30 16:15:13 +0000281 delimiter string. If maxsplit is given, splits at no more than
282 maxsplit places (resulting in at most maxsplit+1 words). If sep
Walter Dörwald065a32f2004-09-14 09:45:10 +0000283 is not specified or is None, any whitespace string is a separator.
Guido van Rossum20032041997-12-29 19:26:28 +0000284
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000285 (split and splitfields are synonymous)
Guido van Rossum20032041997-12-29 19:26:28 +0000286
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000287 """
288 return s.split(sep, maxsplit)
289splitfields = split
Guido van Rossumfac38b71991-04-07 13:42:19 +0000290
Hye-Shik Chang3ae811b2003-12-15 18:49:53 +0000291# Split a string into a list of space/tab-separated words
292def rsplit(s, sep=None, maxsplit=-1):
293 """rsplit(s [,sep [,maxsplit]]) -> list of strings
294
295 Return a list of the words in the string s, using sep as the
296 delimiter string, starting at the end of the string and working
297 to the front. If maxsplit is given, at most maxsplit splits are
298 done. If sep is not specified or is None, any whitespace string
299 is a separator.
300 """
301 return s.rsplit(sep, maxsplit)
302
Guido van Rossum2ab19921995-06-22 18:58:00 +0000303# Join fields with optional separator
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000304def join(words, sep = ' '):
305 """join(list [,sep]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000306
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000307 Return a string composed of the words in list, with
Thomas Wouters7e474022000-07-16 12:04:32 +0000308 intervening occurrences of sep. The default separator is a
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000309 single space.
Guido van Rossum20032041997-12-29 19:26:28 +0000310
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000311 (joinfields and join are synonymous)
Guido van Rossum20032041997-12-29 19:26:28 +0000312
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000313 """
314 return sep.join(words)
315joinfields = join
316
Guido van Rossumd3166071993-05-24 14:16:22 +0000317# Find substring, raise exception if not found
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000318def index(s, *args):
319 """index(s, sub [,start [,end]]) -> int
Guido van Rossum20032041997-12-29 19:26:28 +0000320
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000321 Like find but raises ValueError when the substring is not found.
Guido van Rossum20032041997-12-29 19:26:28 +0000322
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000323 """
Fred Drake046d2722000-07-03 07:23:13 +0000324 return s.index(*args)
Guido van Rossumd3166071993-05-24 14:16:22 +0000325
Guido van Rossume65cce51993-11-08 15:05:21 +0000326# Find last substring, raise exception if not found
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000327def rindex(s, *args):
328 """rindex(s, sub [,start [,end]]) -> int
Guido van Rossum20032041997-12-29 19:26:28 +0000329
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000330 Like rfind but raises ValueError when the substring is not found.
Guido van Rossum20032041997-12-29 19:26:28 +0000331
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000332 """
Fred Drake046d2722000-07-03 07:23:13 +0000333 return s.rindex(*args)
Guido van Rossumb6775db1994-08-01 11:34:53 +0000334
335# Count non-overlapping occurrences of substring
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000336def count(s, *args):
337 """count(s, sub[, start[,end]]) -> int
Guido van Rossum20032041997-12-29 19:26:28 +0000338
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000339 Return the number of occurrences of substring sub in string
340 s[start:end]. Optional arguments start and end are
341 interpreted as in slice notation.
Guido van Rossum20032041997-12-29 19:26:28 +0000342
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000343 """
Fred Drake046d2722000-07-03 07:23:13 +0000344 return s.count(*args)
Guido van Rossume65cce51993-11-08 15:05:21 +0000345
Guido van Rossumd3166071993-05-24 14:16:22 +0000346# Find substring, return -1 if not found
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000347def find(s, *args):
348 """find(s, sub [,start [,end]]) -> in
Guido van Rossum20032041997-12-29 19:26:28 +0000349
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000350 Return the lowest index in s where substring sub is found,
351 such that sub is contained within s[start,end]. Optional
352 arguments start and end are interpreted as in slice notation.
Guido van Rossum20032041997-12-29 19:26:28 +0000353
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000354 Return -1 on failure.
Guido van Rossum20032041997-12-29 19:26:28 +0000355
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000356 """
Fred Drake046d2722000-07-03 07:23:13 +0000357 return s.find(*args)
Guido van Rossumc6360141990-10-13 19:23:40 +0000358
Guido van Rossume65cce51993-11-08 15:05:21 +0000359# Find last substring, return -1 if not found
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000360def rfind(s, *args):
361 """rfind(s, sub [,start [,end]]) -> int
Guido van Rossum20032041997-12-29 19:26:28 +0000362
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000363 Return the highest index in s where substring sub is found,
364 such that sub is contained within s[start,end]. Optional
365 arguments start and end are interpreted as in slice notation.
Guido van Rossum20032041997-12-29 19:26:28 +0000366
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000367 Return -1 on failure.
Guido van Rossum20032041997-12-29 19:26:28 +0000368
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000369 """
Fred Drake046d2722000-07-03 07:23:13 +0000370 return s.rfind(*args)
Guido van Rossume65cce51993-11-08 15:05:21 +0000371
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000372# for a bit of speed
373_float = float
374_int = int
375_long = long
Guido van Rossumd0753e21997-12-10 22:59:55 +0000376
Guido van Rossume61fa0a1993-10-22 13:56:35 +0000377# Convert string to float
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000378def atof(s):
379 """atof(s) -> float
Guido van Rossum20032041997-12-29 19:26:28 +0000380
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000381 Return the floating point number represented by the string s.
Guido van Rossum20032041997-12-29 19:26:28 +0000382
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000383 """
Guido van Rossum9e896b32000-04-05 20:11:21 +0000384 return _float(s)
385
Guido van Rossume61fa0a1993-10-22 13:56:35 +0000386
Guido van Rossumc6360141990-10-13 19:23:40 +0000387# Convert string to integer
Guido van Rossum9e896b32000-04-05 20:11:21 +0000388def atoi(s , base=10):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000389 """atoi(s [,base]) -> int
Guido van Rossum20032041997-12-29 19:26:28 +0000390
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000391 Return the integer represented by the string s in the given
392 base, which defaults to 10. The string s must consist of one
393 or more digits, possibly preceded by a sign. If base is 0, it
394 is chosen from the leading characters of s, 0 for octal, 0x or
395 0X for hexadecimal. If base is 16, a preceding 0x or 0X is
396 accepted.
Guido van Rossum20032041997-12-29 19:26:28 +0000397
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000398 """
Guido van Rossum9e896b32000-04-05 20:11:21 +0000399 return _int(s, base)
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000400
Guido van Rossumc6360141990-10-13 19:23:40 +0000401
Guido van Rossume61fa0a1993-10-22 13:56:35 +0000402# Convert string to long integer
Guido van Rossum9e896b32000-04-05 20:11:21 +0000403def atol(s, base=10):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000404 """atol(s [,base]) -> long
Guido van Rossum20032041997-12-29 19:26:28 +0000405
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000406 Return the long integer represented by the string s in the
407 given base, which defaults to 10. The string s must consist
408 of one or more digits, possibly preceded by a sign. If base
409 is 0, it is chosen from the leading characters of s, 0 for
410 octal, 0x or 0X for hexadecimal. If base is 16, a preceding
411 0x or 0X is accepted. A trailing L or l is not accepted,
412 unless base is 0.
Guido van Rossum20032041997-12-29 19:26:28 +0000413
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000414 """
Guido van Rossum9e896b32000-04-05 20:11:21 +0000415 return _long(s, base)
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000416
Guido van Rossume61fa0a1993-10-22 13:56:35 +0000417
Guido van Rossumc6360141990-10-13 19:23:40 +0000418# Left-justify a string
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000419def ljust(s, width, *args):
420 """ljust(s, width[, fillchar]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000421
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000422 Return a left-justified version of s, in a field of the
423 specified width, padded with spaces as needed. The string is
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000424 never truncated. If specified the fillchar is used instead of spaces.
Guido van Rossum20032041997-12-29 19:26:28 +0000425
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000426 """
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000427 return s.ljust(width, *args)
Guido van Rossumc6360141990-10-13 19:23:40 +0000428
429# Right-justify a string
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000430def rjust(s, width, *args):
431 """rjust(s, width[, fillchar]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000432
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000433 Return a right-justified version of s, in a field of the
434 specified width, padded with spaces as needed. The string is
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000435 never truncated. If specified the fillchar is used instead of spaces.
Guido van Rossum20032041997-12-29 19:26:28 +0000436
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000437 """
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000438 return s.rjust(width, *args)
Guido van Rossumc6360141990-10-13 19:23:40 +0000439
440# Center a string
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000441def center(s, width, *args):
442 """center(s, width[, fillchar]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000443
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000444 Return a center version of s, in a field of the specified
445 width. padded with spaces as needed. The string is never
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000446 truncated. If specified the fillchar is used instead of spaces.
Guido van Rossum20032041997-12-29 19:26:28 +0000447
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000448 """
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000449 return s.center(width, *args)
Guido van Rossumc6360141990-10-13 19:23:40 +0000450
451# Zero-fill a number, e.g., (12, 3) --> '012' and (-3, 3) --> '-03'
452# Decadent feature: the argument may be a string or a number
453# (Use of this is deprecated; it should be a string as with ljust c.s.)
454def zfill(x, width):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000455 """zfill(x, width) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000456
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000457 Pad a numeric string x with zeros on the left, to fill a field
458 of the specified width. The string x is never truncated.
Guido van Rossum20032041997-12-29 19:26:28 +0000459
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000460 """
Walter Dörwald65230a22002-06-03 15:58:32 +0000461 if not isinstance(x, basestring):
Walter Dörwald068325e2002-04-15 13:36:47 +0000462 x = repr(x)
463 return x.zfill(width)
Guido van Rossum6ff2e901992-03-27 15:13:31 +0000464
465# Expand tabs in a string.
466# Doesn't take non-printing chars into account, but does understand \n.
Guido van Rossum894a7bb1995-08-10 19:42:05 +0000467def expandtabs(s, tabsize=8):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000468 """expandtabs(s [,tabsize]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000469
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000470 Return a copy of the string s with all tab characters replaced
471 by the appropriate number of spaces, depending on the current
472 column, and the tabsize (default 8).
Guido van Rossum20032041997-12-29 19:26:28 +0000473
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000474 """
Fred Drake046d2722000-07-03 07:23:13 +0000475 return s.expandtabs(tabsize)
Guido van Rossum2db91351992-10-18 17:09:59 +0000476
Guido van Rossum25395281996-05-28 23:08:45 +0000477# Character translation through look-up table.
Guido van Rossumed7253c1996-07-23 18:12:39 +0000478def translate(s, table, deletions=""):
Guido van Rossum5aff7752000-12-19 02:39:08 +0000479 """translate(s,table [,deletions]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000480
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000481 Return a copy of the string s, where all characters occurring
Guido van Rossum5aff7752000-12-19 02:39:08 +0000482 in the optional argument deletions are removed, and the
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000483 remaining characters have been mapped through the given
Guido van Rossum5aff7752000-12-19 02:39:08 +0000484 translation table, which must be a string of length 256. The
485 deletions argument is not allowed for Unicode strings.
Guido van Rossum20032041997-12-29 19:26:28 +0000486
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000487 """
Guido van Rossum5aff7752000-12-19 02:39:08 +0000488 if deletions:
489 return s.translate(table, deletions)
490 else:
491 # Add s[:0] so that if s is Unicode and table is an 8-bit string,
492 # table is converted to Unicode. This means that table *cannot*
493 # be a dictionary -- for that feature, use u.translate() directly.
494 return s.translate(table + s[:0])
Guido van Rossum2db91351992-10-18 17:09:59 +0000495
Guido van Rossum8775d8b1996-06-11 18:43:00 +0000496# Capitalize a string, e.g. "aBc dEf" -> "Abc def".
497def capitalize(s):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000498 """capitalize(s) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000499
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000500 Return a copy of the string s with only its first character
501 capitalized.
Guido van Rossum20032041997-12-29 19:26:28 +0000502
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000503 """
504 return s.capitalize()
Guido van Rossum8775d8b1996-06-11 18:43:00 +0000505
Guido van Rossum1eb9a811997-03-25 16:50:31 +0000506# Substring replacement (global)
Guido van Rossum8f0c5a72000-03-10 23:22:10 +0000507def replace(s, old, new, maxsplit=-1):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000508 """replace (str, old, new[, maxsplit]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000509
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000510 Return a copy of string str with all occurrences of substring
511 old replaced by new. If the optional argument maxsplit is
512 given, only the first maxsplit occurrences are replaced.
Guido van Rossum20032041997-12-29 19:26:28 +0000513
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000514 """
515 return s.replace(old, new, maxsplit)
Guido van Rossum1eb9a811997-03-25 16:50:31 +0000516
517
Guido van Rossum2db91351992-10-18 17:09:59 +0000518# Try importing optional built-in module "strop" -- if it exists,
519# it redefines some string operations that are 100-1000 times faster.
Guido van Rossum8e2ec561993-07-29 09:37:38 +0000520# It also defines values for whitespace, lowercase and uppercase
521# that match <ctype.h>'s definitions.
Guido van Rossum2db91351992-10-18 17:09:59 +0000522
523try:
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000524 from strop import maketrans, lowercase, uppercase, whitespace
525 letters = lowercase + uppercase
Guido van Rossumb6775db1994-08-01 11:34:53 +0000526except ImportError:
Fred Drake857c4c32000-02-10 16:21:11 +0000527 pass # Use the original versions