python - 尽可能快的类字典匹配

标签 python algorithm optimization data-structures spell-checking

我将不得不在 Python 中执行类似拼写检查的操作,如下所示:

我有一个巨大的单词列表(我们称之为词典)。现在我得到了一些文本(我们称之为示例)。我必须在词典中搜索每个样本词。如果我找不到它,则该示例词是错误的。

简而言之 - 一个强力拼写检查器。然而,线性搜索词典中的每个样本词肯定会很慢。执行此操作的更好方法是什么?

复杂的因素是样本和词典都不是英文的。它是一种语言,而不是 26 个字符,可以有 300 多个 - 存储在 Unicode 中。

任何算法/数据结构/并行化方法的建议都会有所帮助。以低于 100% 的准确度为代价的高速算法将是完美的,因为我不需要 100% 的准确度。我知道 Norvig 的算法,但它似乎是特定于英语的。

最佳答案

您可以使用一组 Unicode 字符串:

s = set(u"rabbit", u"lamb", u"calf")

并使用 in 操作符来检查一个单词是否出现:

>>> u"rabbit" in s
True
>>> u"wolf" in s
False

这个查找本质上是 O(1),所以字典的大小无关紧要。

编辑:这是(区分大小写的)拼写检查器(2.6 或更高版本)的完整代码:

from io import open
import re
with open("dictionary", encoding="utf-8") as f:
    words = set(line.strip() for line in f)
with open("document", encoding="utf-8") as f:
    for w in re.findall(r"\w+", f.read()):
        if w not in words:
            print "Misspelled:", w.encode("utf-8")

(print 假定您的终端使用 UTF-8。)

关于python - 尽可能快的类字典匹配,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10073267/

相关文章:

c++ - 在二维数组的矩形区域内快速找到最大值的方法

c# - 字符串连接优化

python - Django 数据库查询优化与模板中的 iterator()

python - 如何优化这个python代码?我需要改进它的运行时间

python - 在python中解码十六进制utf8字符串

python - 根据字符串列过滤分组数据框中的行

python - 依赖树实现

python - 从 '_io.BytesIO' 转换为 python3.6 中的类字节对象?

c# - 使用数学算法随着时间的推移增加值(value)

算法 - 在一定时间间隔内买卖股票的最佳方式