summaryrefslogtreecommitdiff
path: root/Lib/string.py
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>2000-12-19 02:39:08 +0000
committerGuido van Rossum <guido@python.org>2000-12-19 02:39:08 +0000
commitaee2142eb23856d1d6b48f6a6adece9dbbe97d6c (patch)
tree0baf0326557b1c85de47c495ab5dd1de6ea81c66 /Lib/string.py
parent5a5bc85983d7dc89f93afde9a4d06806fc205910 (diff)
downloadcpython-aee2142eb23856d1d6b48f6a6adece9dbbe97d6c.tar.gz
Make string.translate(s, table) work for Unicode s. Two things are
required to work around restrictions on the arguments of u.translate(): 1) don't pass the deletions argument if it's empty; 2) convert table to Unicode if s is Unicode. This fixes SF bug #124060.
Diffstat (limited to 'Lib/string.py')
-rw-r--r--Lib/string.py15
1 files changed, 11 insertions, 4 deletions
diff --git a/Lib/string.py b/Lib/string.py
index bf2811c6b4..0dffb2afd3 100644
--- a/Lib/string.py
+++ b/Lib/string.py
@@ -297,15 +297,22 @@ def expandtabs(s, tabsize=8):
# Character translation through look-up table.
def translate(s, table, deletions=""):
- """translate(s,table [,deletechars]) -> string
+ """translate(s,table [,deletions]) -> string
Return a copy of the string s, where all characters occurring
- in the optional argument deletechars are removed, and the
+ in the optional argument deletions are removed, and the
remaining characters have been mapped through the given
- translation table, which must be a string of length 256.
+ translation table, which must be a string of length 256. The
+ deletions argument is not allowed for Unicode strings.
"""
- return s.translate(table, deletions)
+ if deletions:
+ return s.translate(table, deletions)
+ else:
+ # Add s[:0] so that if s is Unicode and table is an 8-bit string,
+ # table is converted to Unicode. This means that table *cannot*
+ # be a dictionary -- for that feature, use u.translate() directly.
+ return s.translate(table + s[:0])
# Capitalize a string, e.g. "aBc dEf" -> "Abc def".
def capitalize(s):