blob: ba85a4983540df12a286b9b3f344abd44b890f76 [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".
Barry Warsaw8bee7612004-08-25 02:22:30 +000046def capwords(s, sep=None):
47 """capwords(s, [sep]) -> string
48
49 Split the argument into words using split, capitalize each
50 word using capitalize, and join the capitalized words using
51 join. Note that this replaces runs of whitespace characters by
52 a single space.
53
54 """
55 return (sep or ' ').join([x.capitalize() for x in s.split(sep)])
56
57
58# Construct a translation string
59_idmapL = None
60def maketrans(fromstr, tostr):
61 """maketrans(frm, to) -> string
62
63 Return a translation table (a string of 256 bytes long)
64 suitable for use in string.translate. The strings frm and to
65 must be of the same length.
66
67 """
68 if len(fromstr) != len(tostr):
69 raise ValueError, "maketrans arguments must have same length"
70 global _idmapL
71 if not _idmapL:
72 _idmapL = map(None, _idmap)
73 L = _idmapL[:]
74 fromstr = map(ord, fromstr)
75 for i in range(len(fromstr)):
76 L[fromstr[i]] = tostr[i]
77 return ''.join(L)
78
79
Raymond Hettinger57aef9c2004-12-07 07:55:07 +000080
Raymond Hettinger0d58e2b2004-08-26 00:21:13 +000081####################################################################
Barry Warsaw8bee7612004-08-25 02:22:30 +000082import re as _re
83
Barry Warsaw46b629c2004-09-13 14:35:04 +000084class _multimap:
85 """Helper class for combining multiple mappings.
86
87 Used by .{safe_,}substitute() to combine the mapping and keyword
88 arguments.
89 """
90 def __init__(self, primary, secondary):
91 self._primary = primary
92 self._secondary = secondary
93
94 def __getitem__(self, key):
95 try:
96 return self._primary[key]
97 except KeyError:
98 return self._secondary[key]
99
100
Barry Warsaw12827c12004-09-10 03:08:08 +0000101class _TemplateMetaclass(type):
102 pattern = r"""
Raymond Hettinger55593c32004-09-26 18:56:44 +0000103 %(delim)s(?:
104 (?P<escaped>%(delim)s) | # Escape sequence of two delimiters
105 (?P<named>%(id)s) | # delimiter and a Python identifier
106 {(?P<braced>%(id)s)} | # delimiter and a braced identifier
107 (?P<invalid>) # Other ill-formed delimiter exprs
108 )
Barry Warsaw12827c12004-09-10 03:08:08 +0000109 """
110
111 def __init__(cls, name, bases, dct):
112 super(_TemplateMetaclass, cls).__init__(name, bases, dct)
113 if 'pattern' in dct:
114 pattern = cls.pattern
115 else:
116 pattern = _TemplateMetaclass.pattern % {
Barry Warsaw17cb6002004-09-18 00:06:34 +0000117 'delim' : _re.escape(cls.delimiter),
Barry Warsaw12827c12004-09-10 03:08:08 +0000118 'id' : cls.idpattern,
119 }
120 cls.pattern = _re.compile(pattern, _re.IGNORECASE | _re.VERBOSE)
121
122
123class Template:
Barry Warsaw8bee7612004-08-25 02:22:30 +0000124 """A string class for supporting $-substitutions."""
Barry Warsaw12827c12004-09-10 03:08:08 +0000125 __metaclass__ = _TemplateMetaclass
126
Barry Warsaw17cb6002004-09-18 00:06:34 +0000127 delimiter = '$'
Barry Warsaw12827c12004-09-10 03:08:08 +0000128 idpattern = r'[_a-z][_a-z0-9]*'
129
130 def __init__(self, template):
131 self.template = template
Barry Warsaw8bee7612004-08-25 02:22:30 +0000132
133 # Search for $$, $identifier, ${identifier}, and any bare $'s
Barry Warsaw8bee7612004-08-25 02:22:30 +0000134
Barry Warsawb5c6b5b2004-09-13 20:52:50 +0000135 def _invalid(self, mo):
136 i = mo.start('invalid')
Barry Warsaw12827c12004-09-10 03:08:08 +0000137 lines = self.template[:i].splitlines(True)
138 if not lines:
139 colno = 1
140 lineno = 1
141 else:
142 colno = i - len(''.join(lines[:-1]))
143 lineno = len(lines)
144 raise ValueError('Invalid placeholder in string: line %d, col %d' %
145 (lineno, colno))
146
Barry Warsawb6234a92004-09-13 15:25:15 +0000147 def substitute(self, *args, **kws):
148 if len(args) > 1:
149 raise TypeError('Too many positional arguments')
150 if not args:
151 mapping = kws
Barry Warsaw46b629c2004-09-13 14:35:04 +0000152 elif kws:
Barry Warsawb6234a92004-09-13 15:25:15 +0000153 mapping = _multimap(kws, args[0])
154 else:
155 mapping = args[0]
Barry Warsaw46b629c2004-09-13 14:35:04 +0000156 # Helper function for .sub()
Barry Warsaw8bee7612004-08-25 02:22:30 +0000157 def convert(mo):
Barry Warsawb5c6b5b2004-09-13 20:52:50 +0000158 # Check the most common path first.
159 named = mo.group('named') or mo.group('braced')
160 if named is not None:
161 val = mapping[named]
162 # We use this idiom instead of str() because the latter will
163 # fail if val is a Unicode containing non-ASCII characters.
164 return '%s' % val
Raymond Hettinger0d58e2b2004-08-26 00:21:13 +0000165 if mo.group('escaped') is not None:
Barry Warsaw17cb6002004-09-18 00:06:34 +0000166 return self.delimiter
Barry Warsawb5c6b5b2004-09-13 20:52:50 +0000167 if mo.group('invalid') is not None:
168 self._invalid(mo)
Neal Norwitz6627a962004-10-17 16:27:18 +0000169 raise ValueError('Unrecognized named group in pattern',
170 self.pattern)
Barry Warsaw12827c12004-09-10 03:08:08 +0000171 return self.pattern.sub(convert, self.template)
Barry Warsaw8bee7612004-08-25 02:22:30 +0000172
Barry Warsawb6234a92004-09-13 15:25:15 +0000173 def safe_substitute(self, *args, **kws):
174 if len(args) > 1:
175 raise TypeError('Too many positional arguments')
176 if not args:
177 mapping = kws
Barry Warsaw46b629c2004-09-13 14:35:04 +0000178 elif kws:
Barry Warsawb6234a92004-09-13 15:25:15 +0000179 mapping = _multimap(kws, args[0])
180 else:
181 mapping = args[0]
Barry Warsaw46b629c2004-09-13 14:35:04 +0000182 # Helper function for .sub()
Barry Warsaw8bee7612004-08-25 02:22:30 +0000183 def convert(mo):
Raymond Hettinger0d58e2b2004-08-26 00:21:13 +0000184 named = mo.group('named')
Barry Warsaw8bee7612004-08-25 02:22:30 +0000185 if named is not None:
186 try:
Barry Warsaw12827c12004-09-10 03:08:08 +0000187 # We use this idiom instead of str() because the latter
188 # will fail if val is a Unicode containing non-ASCII
Barry Warsawb6234a92004-09-13 15:25:15 +0000189 return '%s' % mapping[named]
Barry Warsaw8bee7612004-08-25 02:22:30 +0000190 except KeyError:
Barry Warsaw17cb6002004-09-18 00:06:34 +0000191 return self.delimiter + named
Raymond Hettinger0d58e2b2004-08-26 00:21:13 +0000192 braced = mo.group('braced')
Raymond Hettinger6d191112004-09-14 02:34:08 +0000193 if braced is not None:
194 try:
195 return '%s' % mapping[braced]
196 except KeyError:
Barry Warsaw17cb6002004-09-18 00:06:34 +0000197 return self.delimiter + '{' + braced + '}'
Barry Warsawb5c6b5b2004-09-13 20:52:50 +0000198 if mo.group('escaped') is not None:
Barry Warsaw17cb6002004-09-18 00:06:34 +0000199 return self.delimiter
Barry Warsawb5c6b5b2004-09-13 20:52:50 +0000200 if mo.group('invalid') is not None:
Barry Warsaw8c72eae2004-11-01 03:52:43 +0000201 return self.delimiter
Neal Norwitz6627a962004-10-17 16:27:18 +0000202 raise ValueError('Unrecognized named group in pattern',
203 self.pattern)
Barry Warsaw12827c12004-09-10 03:08:08 +0000204 return self.pattern.sub(convert, self.template)
Barry Warsaw8bee7612004-08-25 02:22:30 +0000205
206
Raymond Hettinger57aef9c2004-12-07 07:55:07 +0000207
Raymond Hettinger0d58e2b2004-08-26 00:21:13 +0000208####################################################################
Barry Warsaw8bee7612004-08-25 02:22:30 +0000209# NOTE: Everything below here is deprecated. Use string methods instead.
210# This stuff will go away in Python 3.0.
211
Guido van Rossum710c3521994-08-17 13:16:11 +0000212# Backward compatible names for exceptions
213index_error = ValueError
214atoi_error = ValueError
215atof_error = ValueError
216atol_error = ValueError
217
Guido van Rossumc6360141990-10-13 19:23:40 +0000218# convert UPPER CASE letters to lower case
219def lower(s):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000220 """lower(s) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000221
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000222 Return a copy of the string s converted to lowercase.
Guido van Rossum20032041997-12-29 19:26:28 +0000223
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000224 """
225 return s.lower()
Guido van Rossumc6360141990-10-13 19:23:40 +0000226
227# Convert lower case letters to UPPER CASE
228def upper(s):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000229 """upper(s) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000230
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000231 Return a copy of the string s converted to uppercase.
Guido van Rossum20032041997-12-29 19:26:28 +0000232
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000233 """
234 return s.upper()
Guido van Rossumc6360141990-10-13 19:23:40 +0000235
236# Swap lower case letters and UPPER CASE
237def swapcase(s):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000238 """swapcase(s) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000239
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000240 Return a copy of the string s with upper case characters
241 converted to lowercase and vice versa.
Guido van Rossum20032041997-12-29 19:26:28 +0000242
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000243 """
244 return s.swapcase()
Guido van Rossumc6360141990-10-13 19:23:40 +0000245
246# Strip leading and trailing tabs and spaces
Martin v. Löwis1f046102002-11-08 12:09:59 +0000247def strip(s, chars=None):
Neal Norwitza4864a22002-11-14 03:31:32 +0000248 """strip(s [,chars]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000249
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000250 Return a copy of the string s with leading and trailing
251 whitespace removed.
Neal Norwitzffe33b72003-04-10 22:35:32 +0000252 If chars is given and not None, remove characters in chars instead.
Neal Norwitza4864a22002-11-14 03:31:32 +0000253 If chars is unicode, S will be converted to unicode before stripping.
Guido van Rossum20032041997-12-29 19:26:28 +0000254
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000255 """
Martin v. Löwis1f046102002-11-08 12:09:59 +0000256 return s.strip(chars)
Guido van Rossumc6360141990-10-13 19:23:40 +0000257
Guido van Rossum306a8a61996-08-08 18:40:59 +0000258# Strip leading tabs and spaces
Neal Norwitzffe33b72003-04-10 22:35:32 +0000259def lstrip(s, chars=None):
260 """lstrip(s [,chars]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000261
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000262 Return a copy of the string s with leading whitespace removed.
Neal Norwitzffe33b72003-04-10 22:35:32 +0000263 If chars is given and not None, remove characters in chars instead.
Guido van Rossum20032041997-12-29 19:26:28 +0000264
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000265 """
Neal Norwitzffe33b72003-04-10 22:35:32 +0000266 return s.lstrip(chars)
Guido van Rossum306a8a61996-08-08 18:40:59 +0000267
268# Strip trailing tabs and spaces
Neal Norwitzffe33b72003-04-10 22:35:32 +0000269def rstrip(s, chars=None):
270 """rstrip(s [,chars]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000271
Neal Norwitzffe33b72003-04-10 22:35:32 +0000272 Return a copy of the string s with trailing whitespace removed.
273 If chars is given and not None, remove characters in chars instead.
Guido van Rossum20032041997-12-29 19:26:28 +0000274
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000275 """
Neal Norwitzffe33b72003-04-10 22:35:32 +0000276 return s.rstrip(chars)
Guido van Rossum306a8a61996-08-08 18:40:59 +0000277
278
Guido van Rossumc6360141990-10-13 19:23:40 +0000279# Split a string into a list of space/tab-separated words
Guido van Rossum8f0c5a72000-03-10 23:22:10 +0000280def split(s, sep=None, maxsplit=-1):
Fred Drakee4f13661999-11-04 19:19:48 +0000281 """split(s [,sep [,maxsplit]]) -> list of strings
Guido van Rossum20032041997-12-29 19:26:28 +0000282
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000283 Return a list of the words in the string s, using sep as the
Fred Drake14537542002-01-30 16:15:13 +0000284 delimiter string. If maxsplit is given, splits at no more than
285 maxsplit places (resulting in at most maxsplit+1 words). If sep
Walter Dörwald065a32f2004-09-14 09:45:10 +0000286 is not specified or is None, any whitespace string is a separator.
Guido van Rossum20032041997-12-29 19:26:28 +0000287
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000288 (split and splitfields are synonymous)
Guido van Rossum20032041997-12-29 19:26:28 +0000289
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000290 """
291 return s.split(sep, maxsplit)
292splitfields = split
Guido van Rossumfac38b71991-04-07 13:42:19 +0000293
Hye-Shik Chang3ae811b2003-12-15 18:49:53 +0000294# Split a string into a list of space/tab-separated words
295def rsplit(s, sep=None, maxsplit=-1):
296 """rsplit(s [,sep [,maxsplit]]) -> list of strings
297
298 Return a list of the words in the string s, using sep as the
299 delimiter string, starting at the end of the string and working
300 to the front. If maxsplit is given, at most maxsplit splits are
301 done. If sep is not specified or is None, any whitespace string
302 is a separator.
303 """
304 return s.rsplit(sep, maxsplit)
305
Guido van Rossum2ab19921995-06-22 18:58:00 +0000306# Join fields with optional separator
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000307def join(words, sep = ' '):
308 """join(list [,sep]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000309
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000310 Return a string composed of the words in list, with
Thomas Wouters7e474022000-07-16 12:04:32 +0000311 intervening occurrences of sep. The default separator is a
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000312 single space.
Guido van Rossum20032041997-12-29 19:26:28 +0000313
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000314 (joinfields and join are synonymous)
Guido van Rossum20032041997-12-29 19:26:28 +0000315
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000316 """
317 return sep.join(words)
318joinfields = join
319
Guido van Rossumd3166071993-05-24 14:16:22 +0000320# Find substring, raise exception if not found
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000321def index(s, *args):
322 """index(s, sub [,start [,end]]) -> int
Guido van Rossum20032041997-12-29 19:26:28 +0000323
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000324 Like find but raises ValueError when the substring is not found.
Guido van Rossum20032041997-12-29 19:26:28 +0000325
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000326 """
Fred Drake046d2722000-07-03 07:23:13 +0000327 return s.index(*args)
Guido van Rossumd3166071993-05-24 14:16:22 +0000328
Guido van Rossume65cce51993-11-08 15:05:21 +0000329# Find last substring, raise exception if not found
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000330def rindex(s, *args):
331 """rindex(s, sub [,start [,end]]) -> int
Guido van Rossum20032041997-12-29 19:26:28 +0000332
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000333 Like rfind but raises ValueError when the substring is not found.
Guido van Rossum20032041997-12-29 19:26:28 +0000334
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000335 """
Fred Drake046d2722000-07-03 07:23:13 +0000336 return s.rindex(*args)
Guido van Rossumb6775db1994-08-01 11:34:53 +0000337
338# Count non-overlapping occurrences of substring
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000339def count(s, *args):
340 """count(s, sub[, start[,end]]) -> int
Guido van Rossum20032041997-12-29 19:26:28 +0000341
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000342 Return the number of occurrences of substring sub in string
343 s[start:end]. Optional arguments start and end are
344 interpreted as in slice notation.
Guido van Rossum20032041997-12-29 19:26:28 +0000345
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000346 """
Fred Drake046d2722000-07-03 07:23:13 +0000347 return s.count(*args)
Guido van Rossume65cce51993-11-08 15:05:21 +0000348
Guido van Rossumd3166071993-05-24 14:16:22 +0000349# Find substring, return -1 if not found
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000350def find(s, *args):
351 """find(s, sub [,start [,end]]) -> in
Guido van Rossum20032041997-12-29 19:26:28 +0000352
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000353 Return the lowest index in s where substring sub is found,
354 such that sub is contained within s[start,end]. Optional
355 arguments start and end are interpreted as in slice notation.
Guido van Rossum20032041997-12-29 19:26:28 +0000356
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000357 Return -1 on failure.
Guido van Rossum20032041997-12-29 19:26:28 +0000358
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000359 """
Fred Drake046d2722000-07-03 07:23:13 +0000360 return s.find(*args)
Guido van Rossumc6360141990-10-13 19:23:40 +0000361
Guido van Rossume65cce51993-11-08 15:05:21 +0000362# Find last substring, return -1 if not found
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000363def rfind(s, *args):
364 """rfind(s, sub [,start [,end]]) -> int
Guido van Rossum20032041997-12-29 19:26:28 +0000365
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000366 Return the highest index in s where substring sub is found,
367 such that sub is contained within s[start,end]. Optional
368 arguments start and end are interpreted as in slice notation.
Guido van Rossum20032041997-12-29 19:26:28 +0000369
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000370 Return -1 on failure.
Guido van Rossum20032041997-12-29 19:26:28 +0000371
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000372 """
Fred Drake046d2722000-07-03 07:23:13 +0000373 return s.rfind(*args)
Guido van Rossume65cce51993-11-08 15:05:21 +0000374
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000375# for a bit of speed
376_float = float
377_int = int
378_long = long
Guido van Rossumd0753e21997-12-10 22:59:55 +0000379
Guido van Rossume61fa0a1993-10-22 13:56:35 +0000380# Convert string to float
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000381def atof(s):
382 """atof(s) -> float
Guido van Rossum20032041997-12-29 19:26:28 +0000383
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000384 Return the floating point number represented by the string s.
Guido van Rossum20032041997-12-29 19:26:28 +0000385
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000386 """
Guido van Rossum9e896b32000-04-05 20:11:21 +0000387 return _float(s)
388
Guido van Rossume61fa0a1993-10-22 13:56:35 +0000389
Guido van Rossumc6360141990-10-13 19:23:40 +0000390# Convert string to integer
Guido van Rossum9e896b32000-04-05 20:11:21 +0000391def atoi(s , base=10):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000392 """atoi(s [,base]) -> int
Guido van Rossum20032041997-12-29 19:26:28 +0000393
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000394 Return the integer represented by the string s in the given
395 base, which defaults to 10. The string s must consist of one
396 or more digits, possibly preceded by a sign. If base is 0, it
397 is chosen from the leading characters of s, 0 for octal, 0x or
398 0X for hexadecimal. If base is 16, a preceding 0x or 0X is
399 accepted.
Guido van Rossum20032041997-12-29 19:26:28 +0000400
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000401 """
Guido van Rossum9e896b32000-04-05 20:11:21 +0000402 return _int(s, base)
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000403
Guido van Rossumc6360141990-10-13 19:23:40 +0000404
Guido van Rossume61fa0a1993-10-22 13:56:35 +0000405# Convert string to long integer
Guido van Rossum9e896b32000-04-05 20:11:21 +0000406def atol(s, base=10):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000407 """atol(s [,base]) -> long
Guido van Rossum20032041997-12-29 19:26:28 +0000408
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000409 Return the long integer represented by the string s in the
410 given base, which defaults to 10. The string s must consist
411 of one or more digits, possibly preceded by a sign. If base
412 is 0, it is chosen from the leading characters of s, 0 for
413 octal, 0x or 0X for hexadecimal. If base is 16, a preceding
414 0x or 0X is accepted. A trailing L or l is not accepted,
415 unless base is 0.
Guido van Rossum20032041997-12-29 19:26:28 +0000416
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000417 """
Guido van Rossum9e896b32000-04-05 20:11:21 +0000418 return _long(s, base)
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000419
Guido van Rossume61fa0a1993-10-22 13:56:35 +0000420
Guido van Rossumc6360141990-10-13 19:23:40 +0000421# Left-justify a string
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000422def ljust(s, width, *args):
423 """ljust(s, width[, fillchar]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000424
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000425 Return a left-justified version of s, in a field of the
426 specified width, padded with spaces as needed. The string is
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000427 never truncated. If specified the fillchar is used instead of spaces.
Guido van Rossum20032041997-12-29 19:26:28 +0000428
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000429 """
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000430 return s.ljust(width, *args)
Guido van Rossumc6360141990-10-13 19:23:40 +0000431
432# Right-justify a string
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000433def rjust(s, width, *args):
434 """rjust(s, width[, fillchar]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000435
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000436 Return a right-justified version of s, in a field of the
437 specified width, padded with spaces as needed. The string is
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000438 never truncated. If specified the fillchar is used instead of spaces.
Guido van Rossum20032041997-12-29 19:26:28 +0000439
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000440 """
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000441 return s.rjust(width, *args)
Guido van Rossumc6360141990-10-13 19:23:40 +0000442
443# Center a string
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000444def center(s, width, *args):
445 """center(s, width[, fillchar]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000446
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000447 Return a center version of s, in a field of the specified
448 width. padded with spaces as needed. The string is never
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000449 truncated. If specified the fillchar is used instead of spaces.
Guido van Rossum20032041997-12-29 19:26:28 +0000450
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000451 """
Raymond Hettinger4f8f9762003-11-26 08:21:35 +0000452 return s.center(width, *args)
Guido van Rossumc6360141990-10-13 19:23:40 +0000453
454# Zero-fill a number, e.g., (12, 3) --> '012' and (-3, 3) --> '-03'
455# Decadent feature: the argument may be a string or a number
456# (Use of this is deprecated; it should be a string as with ljust c.s.)
457def zfill(x, width):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000458 """zfill(x, width) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000459
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000460 Pad a numeric string x with zeros on the left, to fill a field
461 of the specified width. The string x is never truncated.
Guido van Rossum20032041997-12-29 19:26:28 +0000462
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000463 """
Walter Dörwald65230a22002-06-03 15:58:32 +0000464 if not isinstance(x, basestring):
Walter Dörwald068325e2002-04-15 13:36:47 +0000465 x = repr(x)
466 return x.zfill(width)
Guido van Rossum6ff2e901992-03-27 15:13:31 +0000467
468# Expand tabs in a string.
469# Doesn't take non-printing chars into account, but does understand \n.
Guido van Rossum894a7bb1995-08-10 19:42:05 +0000470def expandtabs(s, tabsize=8):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000471 """expandtabs(s [,tabsize]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000472
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000473 Return a copy of the string s with all tab characters replaced
474 by the appropriate number of spaces, depending on the current
475 column, and the tabsize (default 8).
Guido van Rossum20032041997-12-29 19:26:28 +0000476
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000477 """
Fred Drake046d2722000-07-03 07:23:13 +0000478 return s.expandtabs(tabsize)
Guido van Rossum2db91351992-10-18 17:09:59 +0000479
Guido van Rossum25395281996-05-28 23:08:45 +0000480# Character translation through look-up table.
Guido van Rossumed7253c1996-07-23 18:12:39 +0000481def translate(s, table, deletions=""):
Guido van Rossum5aff7752000-12-19 02:39:08 +0000482 """translate(s,table [,deletions]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000483
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000484 Return a copy of the string s, where all characters occurring
Guido van Rossum5aff7752000-12-19 02:39:08 +0000485 in the optional argument deletions are removed, and the
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000486 remaining characters have been mapped through the given
Guido van Rossum5aff7752000-12-19 02:39:08 +0000487 translation table, which must be a string of length 256. The
488 deletions argument is not allowed for Unicode strings.
Guido van Rossum20032041997-12-29 19:26:28 +0000489
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000490 """
Guido van Rossum5aff7752000-12-19 02:39:08 +0000491 if deletions:
492 return s.translate(table, deletions)
493 else:
494 # Add s[:0] so that if s is Unicode and table is an 8-bit string,
495 # table is converted to Unicode. This means that table *cannot*
496 # be a dictionary -- for that feature, use u.translate() directly.
497 return s.translate(table + s[:0])
Guido van Rossum2db91351992-10-18 17:09:59 +0000498
Guido van Rossum8775d8b1996-06-11 18:43:00 +0000499# Capitalize a string, e.g. "aBc dEf" -> "Abc def".
500def capitalize(s):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000501 """capitalize(s) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000502
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000503 Return a copy of the string s with only its first character
504 capitalized.
Guido van Rossum20032041997-12-29 19:26:28 +0000505
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000506 """
507 return s.capitalize()
Guido van Rossum8775d8b1996-06-11 18:43:00 +0000508
Guido van Rossum1eb9a811997-03-25 16:50:31 +0000509# Substring replacement (global)
Guido van Rossum8f0c5a72000-03-10 23:22:10 +0000510def replace(s, old, new, maxsplit=-1):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000511 """replace (str, old, new[, maxsplit]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000512
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000513 Return a copy of string str with all occurrences of substring
514 old replaced by new. If the optional argument maxsplit is
515 given, only the first maxsplit occurrences are replaced.
Guido van Rossum20032041997-12-29 19:26:28 +0000516
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000517 """
518 return s.replace(old, new, maxsplit)
Guido van Rossum1eb9a811997-03-25 16:50:31 +0000519
520
Guido van Rossum2db91351992-10-18 17:09:59 +0000521# Try importing optional built-in module "strop" -- if it exists,
522# it redefines some string operations that are 100-1000 times faster.
Guido van Rossum8e2ec561993-07-29 09:37:38 +0000523# It also defines values for whitespace, lowercase and uppercase
524# that match <ctype.h>'s definitions.
Guido van Rossum2db91351992-10-18 17:09:59 +0000525
526try:
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000527 from strop import maketrans, lowercase, uppercase, whitespace
528 letters = lowercase + uppercase
Guido van Rossumb6775db1994-08-01 11:34:53 +0000529except ImportError:
Fred Drake857c4c32000-02-10 16:21:11 +0000530 pass # Use the original versions