summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRaymond Hettinger <python@rcn.com>2009-09-29 18:53:24 (GMT)
committerRaymond Hettinger <python@rcn.com>2009-09-29 18:53:24 (GMT)
commit13305f681ba7ef1bb23c82fee674ec47d822bbbc (patch)
tree13ba9c792fb49f1ffcadac76b5eb2605ffc6515e
parent7248178cd9efb2e568ba71f3293f3be23ef05e5d (diff)
downloadcpython-13305f681ba7ef1bb23c82fee674ec47d822bbbc.zip
cpython-13305f681ba7ef1bb23c82fee674ec47d822bbbc.tar.gz
cpython-13305f681ba7ef1bb23c82fee674ec47d822bbbc.tar.bz2
Issue 7008: Better document str.title and show how to work around the apostrophe problem.
-rw-r--r--Doc/library/stdtypes.rst24
1 files changed, 22 insertions, 2 deletions
diff --git a/Doc/library/stdtypes.rst b/Doc/library/stdtypes.rst
index d2dfd11..25fda8f 100644
--- a/Doc/library/stdtypes.rst
+++ b/Doc/library/stdtypes.rst
@@ -1182,8 +1182,28 @@ string functions based on regular expressions.
.. method:: str.title()
- Return a titlecased version of the string: words start with uppercase
- characters, all remaining cased characters are lowercase.
+ Return a titlecased version of the string where words start with an uppercase
+ character and the remaining characters are lowercase.
+
+ The algorithm uses a simple language-independent definition of a word as
+ groups of consecutive letters. The definition works in many contexts but
+ it means that apostrophes in contractions and possessives form word
+ boundaries, which may not be the desired result::
+
+ >>> "they're bill's friends from the UK".title()
+ "They'Re Bill'S Friends From The Uk"
+
+ A workaround for apostrophes can be constructed using regular expressions::
+
+ >>> import re
+ >>> def titlecase(s):
+ return re.sub(r"[A-Za-z]+('[A-Za-z]+)?",
+ lambda mo: mo.group(0)[0].upper() +
+ mo.group(0)[1:].lower(),
+ s)
+
+ >>> titlecase("they're bill's friends.")
+ "They're Bill's Friends."
For 8-bit strings, this method is locale-dependent.