《Python Cookbook(第2版)中文版》——1.9 简化字符串的translate方法的使用

简介:

本节书摘来自异步社区《Python Cookbook(第2版)中文版》一书中的第1章,第1.9节,作者[美]Alex Martelli , Anna Martelli Ravenscrof , David Ascher ,高铁军 译,更多章节内容可以访问云栖社区“异步社区”公众号查看。

1.9 简化字符串的translate方法的使用

任务

用字符串的translate方法来进行快速编码,但却发现很难记住这个方法和string.maketrans函数的应用细节,所以需要对它们做个简单的封装,以简化其使用流程。
解决方案

字符串的translate方法非常强大而灵活,具体细节可参考第1.10节。正因为它的威力和灵活性,将它“包装”起来以简化应用就成了个好主意。一个返回闭包的工厂函数可以很好地完成这种任务:

import string
def translator(frm='', to='', delete='', keep=None):
      if len(to) == 1:
             to = to * len(frm)
      trans = string.maketrans(frm, to)
      if keep is not None:
             allchars = string.maketrans('', '')
             delete = allchars.translate(allchars, keep.translate(allchars, delete))
      def translate(s):
             return s.translate(trans, delete)
      return translate

讨论

我经常发现我有使用字符串的translate方法的需求,但每次我都得停下来回想它的用法细节(见第1.10节提供的更多细节信息)。所以,我干脆给自己写了个类(后来改写成了本节中展示的工厂闭包的形式),把各种可能性封闭在一个简单易用的接口后面。现在,如果我需要一个函数来选出属于指定集合的字符,我就可以简单地创建并使用它:

>>> digits_only = translator(keep=string.digits)
>>> digits_only('Chris Perkins : 224-7992')
'2247992'

移除属于某字符集合的元素也同样简单:

>>> no_digits = translator(delete=string.digits)
>>> no_digits('Chris Perkins : 224-7992')
'Chris Perkins : -'

甚至,我可以用某个字符替换属于某指定集合的字符:

>>> digits_to_hash = translator(from=string.digits, to='#')
>>> digits_to_hash('Chris Perkins : 224-7992')
'Chris Perkins : ###-####'

虽然后面那个应用显得有点特殊,但我仍然不时地碰到有这种需求的任务。

当然,我的设计有点武断,当delete参数和keep参数有重叠部分的时候,我让delete参数优先:

>>> trans = translator(delete='abcd', keep='cdef')
>>> trans('abcdefg')
'ef'

对于你的程序,如果keep被指定了,可能忽略掉delete会更好一些,再或者,如果两者都被指定了,抛出个异常也不错,因为在一个对translator的调用中同时指定两者可能没什么意义。另外,和第1.8节和第1.10节相似,本节代码只适用于普通字符串,对Unicode字符串并不适用。参看第1.10节,可以了解到怎样为Unicode字符串编写类似功能的代码,并可看到Unicode的translate方法与普通(单字节)字符串的translate的区别。

闭包 闭包(closure)不是什么复杂得不得了的东西:它只不过是个“内层”的函数,由一个名字(变量)来指代,而这个名字(变量)对于“外层”包含它的函数而言,是本地变量。我们用一个教科书般的例子来说明: def make_adder(addend): def adder(augend): return augend+addend return adder 执行p = make_addr(23)将产生内层函数adder的一个闭包,这个闭包在内部引用了名字addend,而addend又绑定到数值23。q = make_adder(42)又产生另一个闭包,这次名字addend则绑定到了值42。q和p相互之间并无关联,因此它们可以相互独立地和谐共存。现在我们就可以执行它们了,比如,print p(100), q(100)将打印出123 142。 实际上,我们一般认为make_adder指向一个闭包,而不是说什么迂腐拗口的“一个返回闭包的函数”—幸运的是,根据上下文环境,通常这样也不至于造成误解。称make_adder为一个工厂(或者工厂函数)也是简洁明确的;还可以称它为一个闭包工厂来强调它创建并返回闭包,而不是返回类或者类的实例。

相关文章
|
4月前
|
测试技术 开发者 Python
Python单元测试入门:3个核心断言方法,帮你快速定位代码bug
本文介绍Python单元测试基础,详解`unittest`框架中的三大核心断言方法:`assertEqual`验证值相等,`assertTrue`和`assertFalse`判断条件真假。通过实例演示其用法,帮助开发者自动化检测代码逻辑,提升测试效率与可靠性。
431 1
|
4月前
|
Python
Python中的f-string:更优雅的字符串格式化
Python中的f-string:更优雅的字符串格式化
367 100
|
4月前
|
开发者 Python
Python中的f-string:高效字符串格式化的利器
Python中的f-string:高效字符串格式化的利器
511 99
|
4月前
|
Python
Python中的f-string:更优雅的字符串格式化
Python中的f-string:更优雅的字符串格式化
|
4月前
|
开发者 Python
Python f-strings:更优雅的字符串格式化技巧
Python f-strings:更优雅的字符串格式化技巧
|
4月前
|
开发者 Python
Python f-string:高效字符串格式化的艺术
Python f-string:高效字符串格式化的艺术
|
4月前
|
人工智能 数据安全/隐私保护 异构计算
桌面版exe安装和Python命令行安装2种方法详细讲解图片去水印AI源码私有化部署Lama-Cleaner安装使用方法-优雅草卓伊凡
桌面版exe安装和Python命令行安装2种方法详细讲解图片去水印AI源码私有化部署Lama-Cleaner安装使用方法-优雅草卓伊凡
552 8
桌面版exe安装和Python命令行安装2种方法详细讲解图片去水印AI源码私有化部署Lama-Cleaner安装使用方法-优雅草卓伊凡
|
3月前
|
存储 Java 索引
(Python基础)新时代语言!一起学习Python吧!(二):字符编码由来;Python字符串、字符串格式化;list集合和tuple元组区别
字符编码 我们要清楚,计算机最开始的表达都是由二进制而来 我们要想通过二进制来表示我们熟知的字符看看以下的变化 例如: 1 的二进制编码为 0000 0001 我们通过A这个字符,让其在计算机内部存储(现如今,A 字符在地址通常表示为65) 现在拿A举例: 在计算机内部 A字符,它本身表示为 65这个数,在计算机底层会转为二进制码 也意味着A字符在底层表示为 1000001 通过这样的字符表示进行转换,逐步发展为拥有127个字符的编码存储到计算机中,这个编码表也被称为ASCII编码。 但随时代变迁,ASCII编码逐渐暴露短板,全球有上百种语言,光是ASCII编码并不能够满足需求
198 4
|
SQL JSON C语言
Python中字符串的三种定义方法
Python中字符串的三种定义方法
637 2

推荐镜像

更多