blob: bdd9254966d50ceb23b32aad4d0da7090163c4b8 [file] [log] [blame]
Guido van Rossume7b146f2000-02-04 15:28:42 +00001"""A collection of string operations (most are no longer used in Python 1.6).
Guido van Rossumc6360141990-10-13 19:23:40 +00002
Guido van Rossume7b146f2000-02-04 15:28:42 +00003Warning: most of the code you see here isn't normally used nowadays. With
4Python 1.6, many of these functions are implemented as methods on the
5standard string object. They used to be implemented by a built-in module
6called 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
27digits = '0123456789'
28hexdigits = digits + 'abcdef' + 'ABCDEF'
29octdigits = '01234567'
Tim Peters495ad3c2001-01-15 01:36:40 +000030punctuation = """!"#$%&'()*+,-./:;<=>?@[\]^_`{|}~"""
Fred Drake6b2320f2000-09-18 16:46:17 +000031printable = digits + letters + punctuation + whitespace
Guido van Rossumc6360141990-10-13 19:23:40 +000032
33# Case conversion helpers
Guido van Rossuma61ff7b1992-01-14 18:31:29 +000034_idmap = ''
35for i in range(256): _idmap = _idmap + chr(i)
Guido van Rossumc6360141990-10-13 19:23:40 +000036del i
37
Guido van Rossum710c3521994-08-17 13:16:11 +000038# Backward compatible names for exceptions
39index_error = ValueError
40atoi_error = ValueError
41atof_error = ValueError
42atol_error = ValueError
43
Guido van Rossumc6360141990-10-13 19:23:40 +000044# convert UPPER CASE letters to lower case
45def lower(s):
Barry Warsaw226ae6c1999-10-12 19:54:53 +000046 """lower(s) -> string
Guido van Rossum20032041997-12-29 19:26:28 +000047
Barry Warsaw226ae6c1999-10-12 19:54:53 +000048 Return a copy of the string s converted to lowercase.
Guido van Rossum20032041997-12-29 19:26:28 +000049
Barry Warsaw226ae6c1999-10-12 19:54:53 +000050 """
51 return s.lower()
Guido van Rossumc6360141990-10-13 19:23:40 +000052
53# Convert lower case letters to UPPER CASE
54def upper(s):
Barry Warsaw226ae6c1999-10-12 19:54:53 +000055 """upper(s) -> string
Guido van Rossum20032041997-12-29 19:26:28 +000056
Barry Warsaw226ae6c1999-10-12 19:54:53 +000057 Return a copy of the string s converted to uppercase.
Guido van Rossum20032041997-12-29 19:26:28 +000058
Barry Warsaw226ae6c1999-10-12 19:54:53 +000059 """
60 return s.upper()
Guido van Rossumc6360141990-10-13 19:23:40 +000061
62# Swap lower case letters and UPPER CASE
63def swapcase(s):
Barry Warsaw226ae6c1999-10-12 19:54:53 +000064 """swapcase(s) -> string
Guido van Rossum20032041997-12-29 19:26:28 +000065
Barry Warsaw226ae6c1999-10-12 19:54:53 +000066 Return a copy of the string s with upper case characters
67 converted to lowercase and vice versa.
Guido van Rossum20032041997-12-29 19:26:28 +000068
Barry Warsaw226ae6c1999-10-12 19:54:53 +000069 """
70 return s.swapcase()
Guido van Rossumc6360141990-10-13 19:23:40 +000071
72# Strip leading and trailing tabs and spaces
73def strip(s):
Barry Warsaw226ae6c1999-10-12 19:54:53 +000074 """strip(s) -> string
Guido van Rossum20032041997-12-29 19:26:28 +000075
Barry Warsaw226ae6c1999-10-12 19:54:53 +000076 Return a copy of the string s with leading and trailing
77 whitespace removed.
Guido van Rossum20032041997-12-29 19:26:28 +000078
Barry Warsaw226ae6c1999-10-12 19:54:53 +000079 """
80 return s.strip()
Guido van Rossumc6360141990-10-13 19:23:40 +000081
Guido van Rossum306a8a61996-08-08 18:40:59 +000082# Strip leading tabs and spaces
83def lstrip(s):
Barry Warsaw226ae6c1999-10-12 19:54:53 +000084 """lstrip(s) -> string
Guido van Rossum20032041997-12-29 19:26:28 +000085
Barry Warsaw226ae6c1999-10-12 19:54:53 +000086 Return a copy of the string s with leading whitespace removed.
Guido van Rossum20032041997-12-29 19:26:28 +000087
Barry Warsaw226ae6c1999-10-12 19:54:53 +000088 """
89 return s.lstrip()
Guido van Rossum306a8a61996-08-08 18:40:59 +000090
91# Strip trailing tabs and spaces
92def rstrip(s):
Barry Warsaw226ae6c1999-10-12 19:54:53 +000093 """rstrip(s) -> string
Guido van Rossum20032041997-12-29 19:26:28 +000094
Barry Warsaw226ae6c1999-10-12 19:54:53 +000095 Return a copy of the string s with trailing whitespace
96 removed.
Guido van Rossum20032041997-12-29 19:26:28 +000097
Barry Warsaw226ae6c1999-10-12 19:54:53 +000098 """
99 return s.rstrip()
Guido van Rossum306a8a61996-08-08 18:40:59 +0000100
101
Guido van Rossumc6360141990-10-13 19:23:40 +0000102# Split a string into a list of space/tab-separated words
103# NB: split(s) is NOT the same as splitfields(s, ' ')!
Guido van Rossum8f0c5a72000-03-10 23:22:10 +0000104def split(s, sep=None, maxsplit=-1):
Fred Drakee4f13661999-11-04 19:19:48 +0000105 """split(s [,sep [,maxsplit]]) -> list of strings
Guido van Rossum20032041997-12-29 19:26:28 +0000106
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000107 Return a list of the words in the string s, using sep as the
Guido van Rossum8f0c5a72000-03-10 23:22:10 +0000108 delimiter string. If maxsplit is given, splits into at most
Fred Drakee4f13661999-11-04 19:19:48 +0000109 maxsplit words. If sep is not specified, any whitespace string
Guido van Rossum8f0c5a72000-03-10 23:22:10 +0000110 is a separator.
Guido van Rossum20032041997-12-29 19:26:28 +0000111
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000112 (split and splitfields are synonymous)
Guido van Rossum20032041997-12-29 19:26:28 +0000113
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000114 """
115 return s.split(sep, maxsplit)
116splitfields = split
Guido van Rossumfac38b71991-04-07 13:42:19 +0000117
Guido van Rossum2ab19921995-06-22 18:58:00 +0000118# Join fields with optional separator
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000119def join(words, sep = ' '):
120 """join(list [,sep]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000121
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000122 Return a string composed of the words in list, with
Thomas Wouters7e474022000-07-16 12:04:32 +0000123 intervening occurrences of sep. The default separator is a
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000124 single space.
Guido van Rossum20032041997-12-29 19:26:28 +0000125
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000126 (joinfields and join are synonymous)
Guido van Rossum20032041997-12-29 19:26:28 +0000127
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000128 """
129 return sep.join(words)
130joinfields = join
131
Guido van Rossumd3166071993-05-24 14:16:22 +0000132# Find substring, raise exception if not found
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000133def index(s, *args):
134 """index(s, sub [,start [,end]]) -> int
Guido van Rossum20032041997-12-29 19:26:28 +0000135
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000136 Like find but raises ValueError when the substring is not found.
Guido van Rossum20032041997-12-29 19:26:28 +0000137
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000138 """
Fred Drake046d2722000-07-03 07:23:13 +0000139 return s.index(*args)
Guido van Rossumd3166071993-05-24 14:16:22 +0000140
Guido van Rossume65cce51993-11-08 15:05:21 +0000141# Find last substring, raise exception if not found
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000142def rindex(s, *args):
143 """rindex(s, sub [,start [,end]]) -> int
Guido van Rossum20032041997-12-29 19:26:28 +0000144
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000145 Like rfind but raises ValueError when the substring is not found.
Guido van Rossum20032041997-12-29 19:26:28 +0000146
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000147 """
Fred Drake046d2722000-07-03 07:23:13 +0000148 return s.rindex(*args)
Guido van Rossumb6775db1994-08-01 11:34:53 +0000149
150# Count non-overlapping occurrences of substring
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000151def count(s, *args):
152 """count(s, sub[, start[,end]]) -> int
Guido van Rossum20032041997-12-29 19:26:28 +0000153
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000154 Return the number of occurrences of substring sub in string
155 s[start:end]. Optional arguments start and end are
156 interpreted as in slice notation.
Guido van Rossum20032041997-12-29 19:26:28 +0000157
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000158 """
Fred Drake046d2722000-07-03 07:23:13 +0000159 return s.count(*args)
Guido van Rossume65cce51993-11-08 15:05:21 +0000160
Guido van Rossumd3166071993-05-24 14:16:22 +0000161# Find substring, return -1 if not found
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000162def find(s, *args):
163 """find(s, sub [,start [,end]]) -> in
Guido van Rossum20032041997-12-29 19:26:28 +0000164
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000165 Return the lowest index in s where substring sub is found,
166 such that sub is contained within s[start,end]. Optional
167 arguments start and end are interpreted as in slice notation.
Guido van Rossum20032041997-12-29 19:26:28 +0000168
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000169 Return -1 on failure.
Guido van Rossum20032041997-12-29 19:26:28 +0000170
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000171 """
Fred Drake046d2722000-07-03 07:23:13 +0000172 return s.find(*args)
Guido van Rossumc6360141990-10-13 19:23:40 +0000173
Guido van Rossume65cce51993-11-08 15:05:21 +0000174# Find last substring, return -1 if not found
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000175def rfind(s, *args):
176 """rfind(s, sub [,start [,end]]) -> int
Guido van Rossum20032041997-12-29 19:26:28 +0000177
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000178 Return the highest index in s where substring sub is found,
179 such that sub is contained within s[start,end]. Optional
180 arguments start and end are interpreted as in slice notation.
Guido van Rossum20032041997-12-29 19:26:28 +0000181
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000182 Return -1 on failure.
Guido van Rossum20032041997-12-29 19:26:28 +0000183
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000184 """
Fred Drake046d2722000-07-03 07:23:13 +0000185 return s.rfind(*args)
Guido van Rossume65cce51993-11-08 15:05:21 +0000186
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000187# for a bit of speed
188_float = float
189_int = int
190_long = long
191_StringType = type('')
Guido van Rossumd0753e21997-12-10 22:59:55 +0000192
Guido van Rossume61fa0a1993-10-22 13:56:35 +0000193# Convert string to float
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000194def atof(s):
195 """atof(s) -> float
Guido van Rossum20032041997-12-29 19:26:28 +0000196
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000197 Return the floating point number represented by the string s.
Guido van Rossum20032041997-12-29 19:26:28 +0000198
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000199 """
Guido van Rossum9e896b32000-04-05 20:11:21 +0000200 return _float(s)
201
Guido van Rossume61fa0a1993-10-22 13:56:35 +0000202
Guido van Rossumc6360141990-10-13 19:23:40 +0000203# Convert string to integer
Guido van Rossum9e896b32000-04-05 20:11:21 +0000204def atoi(s , base=10):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000205 """atoi(s [,base]) -> int
Guido van Rossum20032041997-12-29 19:26:28 +0000206
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000207 Return the integer represented by the string s in the given
208 base, which defaults to 10. The string s must consist of one
209 or more digits, possibly preceded by a sign. If base is 0, it
210 is chosen from the leading characters of s, 0 for octal, 0x or
211 0X for hexadecimal. If base is 16, a preceding 0x or 0X is
212 accepted.
Guido van Rossum20032041997-12-29 19:26:28 +0000213
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000214 """
Guido van Rossum9e896b32000-04-05 20:11:21 +0000215 return _int(s, base)
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000216
Guido van Rossumc6360141990-10-13 19:23:40 +0000217
Guido van Rossume61fa0a1993-10-22 13:56:35 +0000218# Convert string to long integer
Guido van Rossum9e896b32000-04-05 20:11:21 +0000219def atol(s, base=10):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000220 """atol(s [,base]) -> long
Guido van Rossum20032041997-12-29 19:26:28 +0000221
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000222 Return the long integer represented by the string s in the
223 given base, which defaults to 10. The string s must consist
224 of one or more digits, possibly preceded by a sign. If base
225 is 0, it is chosen from the leading characters of s, 0 for
226 octal, 0x or 0X for hexadecimal. If base is 16, a preceding
227 0x or 0X is accepted. A trailing L or l is not accepted,
228 unless base is 0.
Guido van Rossum20032041997-12-29 19:26:28 +0000229
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000230 """
Guido van Rossum9e896b32000-04-05 20:11:21 +0000231 return _long(s, base)
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000232
Guido van Rossume61fa0a1993-10-22 13:56:35 +0000233
Guido van Rossumc6360141990-10-13 19:23:40 +0000234# Left-justify a string
235def ljust(s, width):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000236 """ljust(s, width) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000237
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000238 Return a left-justified version of s, in a field of the
239 specified width, padded with spaces as needed. The string is
240 never truncated.
Guido van Rossum20032041997-12-29 19:26:28 +0000241
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000242 """
Fred Drake046d2722000-07-03 07:23:13 +0000243 return s.ljust(width)
Guido van Rossumc6360141990-10-13 19:23:40 +0000244
245# Right-justify a string
246def rjust(s, width):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000247 """rjust(s, width) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000248
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000249 Return a right-justified version of s, in a field of the
250 specified width, padded with spaces as needed. The string is
251 never truncated.
Guido van Rossum20032041997-12-29 19:26:28 +0000252
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000253 """
Fred Drake046d2722000-07-03 07:23:13 +0000254 return s.rjust(width)
Guido van Rossumc6360141990-10-13 19:23:40 +0000255
256# Center a string
257def center(s, width):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000258 """center(s, width) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000259
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000260 Return a center version of s, in a field of the specified
261 width. padded with spaces as needed. The string is never
262 truncated.
Guido van Rossum20032041997-12-29 19:26:28 +0000263
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000264 """
Fred Drake046d2722000-07-03 07:23:13 +0000265 return s.center(width)
Guido van Rossumc6360141990-10-13 19:23:40 +0000266
267# Zero-fill a number, e.g., (12, 3) --> '012' and (-3, 3) --> '-03'
268# Decadent feature: the argument may be a string or a number
269# (Use of this is deprecated; it should be a string as with ljust c.s.)
270def zfill(x, width):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000271 """zfill(x, width) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000272
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000273 Pad a numeric string x with zeros on the left, to fill a field
274 of the specified width. The string x is never truncated.
Guido van Rossum20032041997-12-29 19:26:28 +0000275
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000276 """
277 if type(x) == type(''): s = x
278 else: s = `x`
279 n = len(s)
280 if n >= width: return s
281 sign = ''
282 if s[0] in ('-', '+'):
Fred Drake857c4c32000-02-10 16:21:11 +0000283 sign, s = s[0], s[1:]
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000284 return sign + '0'*(width-n) + s
Guido van Rossum6ff2e901992-03-27 15:13:31 +0000285
286# Expand tabs in a string.
287# Doesn't take non-printing chars into account, but does understand \n.
Guido van Rossum894a7bb1995-08-10 19:42:05 +0000288def expandtabs(s, tabsize=8):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000289 """expandtabs(s [,tabsize]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000290
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000291 Return a copy of the string s with all tab characters replaced
292 by the appropriate number of spaces, depending on the current
293 column, and the tabsize (default 8).
Guido van Rossum20032041997-12-29 19:26:28 +0000294
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000295 """
Fred Drake046d2722000-07-03 07:23:13 +0000296 return s.expandtabs(tabsize)
Guido van Rossum2db91351992-10-18 17:09:59 +0000297
Guido van Rossum25395281996-05-28 23:08:45 +0000298# Character translation through look-up table.
Guido van Rossumed7253c1996-07-23 18:12:39 +0000299def translate(s, table, deletions=""):
Guido van Rossum5aff7752000-12-19 02:39:08 +0000300 """translate(s,table [,deletions]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000301
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000302 Return a copy of the string s, where all characters occurring
Guido van Rossum5aff7752000-12-19 02:39:08 +0000303 in the optional argument deletions are removed, and the
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000304 remaining characters have been mapped through the given
Guido van Rossum5aff7752000-12-19 02:39:08 +0000305 translation table, which must be a string of length 256. The
306 deletions argument is not allowed for Unicode strings.
Guido van Rossum20032041997-12-29 19:26:28 +0000307
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000308 """
Guido van Rossum5aff7752000-12-19 02:39:08 +0000309 if deletions:
310 return s.translate(table, deletions)
311 else:
312 # Add s[:0] so that if s is Unicode and table is an 8-bit string,
313 # table is converted to Unicode. This means that table *cannot*
314 # be a dictionary -- for that feature, use u.translate() directly.
315 return s.translate(table + s[:0])
Guido van Rossum2db91351992-10-18 17:09:59 +0000316
Guido van Rossum8775d8b1996-06-11 18:43:00 +0000317# Capitalize a string, e.g. "aBc dEf" -> "Abc def".
318def capitalize(s):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000319 """capitalize(s) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000320
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000321 Return a copy of the string s with only its first character
322 capitalized.
Guido van Rossum20032041997-12-29 19:26:28 +0000323
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000324 """
325 return s.capitalize()
Guido van Rossum8775d8b1996-06-11 18:43:00 +0000326
327# Capitalize the words in a string, e.g. " aBc dEf " -> "Abc Def".
328# See also regsub.capwords().
Guido van Rossum34f17311996-08-20 20:25:41 +0000329def capwords(s, sep=None):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000330 """capwords(s, [sep]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000331
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000332 Split the argument into words using split, capitalize each
333 word using capitalize, and join the capitalized words using
334 join. Note that this replaces runs of whitespace characters by
335 a single space.
Guido van Rossum20032041997-12-29 19:26:28 +0000336
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000337 """
338 return join(map(capitalize, s.split(sep)), sep or ' ')
Guido van Rossum8775d8b1996-06-11 18:43:00 +0000339
Guido van Rossumed7253c1996-07-23 18:12:39 +0000340# Construct a translation string
341_idmapL = None
342def maketrans(fromstr, tostr):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000343 """maketrans(frm, to) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000344
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000345 Return a translation table (a string of 256 bytes long)
346 suitable for use in string.translate. The strings frm and to
347 must be of the same length.
Guido van Rossum20032041997-12-29 19:26:28 +0000348
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000349 """
350 if len(fromstr) != len(tostr):
Fred Drake857c4c32000-02-10 16:21:11 +0000351 raise ValueError, "maketrans arguments must have same length"
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000352 global _idmapL
353 if not _idmapL:
Fred Drake857c4c32000-02-10 16:21:11 +0000354 _idmapL = map(None, _idmap)
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000355 L = _idmapL[:]
356 fromstr = map(ord, fromstr)
357 for i in range(len(fromstr)):
Fred Drake857c4c32000-02-10 16:21:11 +0000358 L[fromstr[i]] = tostr[i]
Eric S. Raymonde37340e2001-02-09 16:56:44 +0000359 return join(L, "")
Guido van Rossum8775d8b1996-06-11 18:43:00 +0000360
Guido van Rossum1eb9a811997-03-25 16:50:31 +0000361# Substring replacement (global)
Guido van Rossum8f0c5a72000-03-10 23:22:10 +0000362def replace(s, old, new, maxsplit=-1):
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000363 """replace (str, old, new[, maxsplit]) -> string
Guido van Rossum20032041997-12-29 19:26:28 +0000364
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000365 Return a copy of string str with all occurrences of substring
366 old replaced by new. If the optional argument maxsplit is
367 given, only the first maxsplit occurrences are replaced.
Guido van Rossum20032041997-12-29 19:26:28 +0000368
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000369 """
370 return s.replace(old, new, maxsplit)
Guido van Rossum1eb9a811997-03-25 16:50:31 +0000371
372
Guido van Rossum2db91351992-10-18 17:09:59 +0000373# Try importing optional built-in module "strop" -- if it exists,
374# it redefines some string operations that are 100-1000 times faster.
Guido van Rossum8e2ec561993-07-29 09:37:38 +0000375# It also defines values for whitespace, lowercase and uppercase
376# that match <ctype.h>'s definitions.
Guido van Rossum2db91351992-10-18 17:09:59 +0000377
378try:
Barry Warsaw226ae6c1999-10-12 19:54:53 +0000379 from strop import maketrans, lowercase, uppercase, whitespace
380 letters = lowercase + uppercase
Guido van Rossumb6775db1994-08-01 11:34:53 +0000381except ImportError:
Fred Drake857c4c32000-02-10 16:21:11 +0000382 pass # Use the original versions