代码:
charToSoundex = {"A": "9",
"B": "1",
"C": "2",
"D": "3",
"E": "9",
"F": "1",
"G": "2",
"H": "9",
"I": "9",
"J": "2",
"K": "2",
"L": "4",
"M": "5",
"N": "5",
"O": "9",
"P": "1",
"Q": "2",
"R": "6",
"S": "2",
"T": "3",
"U": "9",
"V": "1",
"W": "9",
"X": "2",
"Y": "9",
"Z": "2"}
def soundex(source):
# ... input check omitted for brevity ...
source = source[0].upper() + source[1:]
digits = source[0]
for s in source[1:]:
s = s.upper()
digits += charToSoundex[s]
测试性能
C:\samples\soundex\stage1>python soundex1c.py
Woo W000 14.5341678901
Pilgrim P426 19.2650071448
Flingjingwaller F452 30.1003563302
优化代码2
def soundex(source):
# ...
source = source.upper()
digits = source[0] + "".join(map(lambda c: charToSoundex[c], source[1:]))
测试性能
C:\samples\soundex\stage2>python soundex2a.py
Woo W000 15.0097526362
Pilgrim P426 19.254806407
Flingjingwaller F452 29.3790847719
匿名函数的开销抵消了用过把string作为一组字符进行出来带来的性能优化
优化代码3
source = source.upper()
digits = source[0] + "".join([charToSoundex[c] for c in source[1:]])
测试性能
C:\samples\soundex\stage2>python soundex2b.py
Woo W000 13.4221324219
Pilgrim P426 16.4901234654
Flingjingwaller F452 25.8186157738
可以字符串处理最好用list
优化代码4
allChar = string.uppercase + string.lowercase
charToSoundex = string.maketrans(allChar, "91239129922455912623919292" * 2)
def soundex(source):
# ...
digits = source[0].upper() + source[1:].translate(charToSoundex)
测试性能
C:\samples\soundex\stage2>python soundex2c.py
Woo W000 11.437645008
Pilgrim P426 13.2825062962
Flingjingwaller F452 18.5570110168
string.maketrans创建了字符和数字之间转换的联系,这种数据结构比map要快很多
分享到:
相关推荐
原来是通过命令行下载的docx安装包还没有完全兼容python3,估计这个安装包还只兼容python 2(python2 和python3差别还是挺大的,虽然现在python 3出来很久了,但是不少三方库还没有更新),因此需要自己找一个兼容的包...
python-3.10.8 64位windows 安装包,直接双击安装即可,包内文件名为:python-3.10.8-amd64.exe
python-3.8.0-amd64.exe, python-windows平台,使用64位,exe安装包
最新版windows python-3.8.6-amd64.exe最新版windows python-3.8.6-amd64.exe
python-urlgrabber-3.9.1-11.el6.noarch.rpm
python-2.7.5-90.el7.x86_64.rpm
python课程设计-酒店房间预订及管理系统python课程设计-酒店房间预订及管理系统python课程设计-酒店房间预订及管理系统python课程设计-酒店房间预订及管理系统python课程设计-酒店房间预订及管理系统python课程设计-...
python-3.7.0-amd64 安装包
OpenCV-Python-Toturial-中文版.pdf
python-3.7.3-amd64.exe Python 3.7.3 for Windows x64位 or 32位 Windows x86-64 executable installer MD5: a2b79563476e9aa47f11899a53349383 File Size: 26190920 请不要给我5星好评,因为好评会上涨下载积分!
其实pip list python-docx 安装不成功,安装一般就报错,主要原因是从官网的下载不稳定,而且慢,经常会断,只能先下下来,然后放到cmd所在的文件夹或者指定路径,pip list python-docx-0.8.10.tar.gz,很快就好了!
opencv_python-4.4.0-cp36-cp36m-win_amd64.whl python 3.6 版本的64位计算机的opencv本地安装文件
python学习笔记,包含python字典-集合-不可变集合-赋值机制
Python性能优化-TaoBeier@meitu.pdf
python-3.7.6 windows版 在电脑上写python代码 可以结合visual使用python-3.7.6 windows版 在电脑上写python代码 可以结合visual使用 python-3.7.6 windows版 在电脑上写python代码 可以结合visual使用
mysql-connector-python-2.0.4-py3.4
详解python实现FP-TREE进行关联规则挖掘 python3.2实现,可以生成每一步fp树的图片(需要安装PIL)
python学习教程--06-字典常用操作之查找.ev4.rar
python 下的多图像拼接源代码,供学习参考! python 下的多图像拼接源代码,供学习参考! python 下的多图像拼接源代码,供学习参考!
python-iniparse-0.3.1-2.1.el6.noarch.rpm