Python 多模式字符串搜索 Aho-Corasick详解

 更新时间:2025年01月19日 11:22:32   作者:言之。  
Aho-Corasick 算法是一种用于精确或近似多模式字符串搜索的高效算法,本文给大家介绍Python 多模式字符串搜索 Aho-Corasick的相关知识,感兴趣的朋友跟随小编一起看看吧

ahocorasick.Automaton 是 Python 中 pyahocorasick 库提供的一个类,用于实现 Aho-Corasick 自动机。Aho-Corasick 算法是一种用于精确或近似多模式字符串搜索的高效算法。

通过 pip install pyahocorasick 安装 pyahocorasick 库。
并且,该模块是用 C 编写的,安装时需要有 C 编译器来编译本机 Cpython 扩展。

使用 ahocorasick.Automaton 类的一般步骤如下:

  • 导入 ahocorasick 库:import ahocorasick
  • 创建 Automaton 对象:a = ahocorasick.Automaton()
  • (可选)将字符串键及其关联值添加到自动机,可作为 trie 树使用。例如:
for idx, key in enumerate('heherhersshe'.split()):
    a.add_word(key, (idx, key))

调用 make_automaton() 方法完成并创建 Aho-Corasick 自动机:a.make_automaton()

创建好自动机后,可以使用以下主要方法进行搜索操作:

  • iter(string, (start, (end))):使用提供的输入字符串执行 Aho-Corasick 搜索过程。它返回一个迭代器,为在字符串中找到的键返回元组 (end_index, value),其中 end_index 是匹配结束的索引位置,value 是与匹配的键相关联的值。
  • iter_long(string, (start, (end))):返回一个搜索最长、非重叠匹配的迭代器(automaton_search_iter_long 类的对象)。

以下是一个使用 ahocorasick.Automaton 进行多模式字符串搜索的示例代码:

import ahocorasick as ah
a = ah.automaton()
with open('userdict.txt', 'r', encoding='utf-8') as f2:  # 加载文件
    keywords = (a.strip() for a in f2.readlines())  # 加载关键词
    # 利用 add_word 方法将关键词加入自动机!
    for x in range(len(keywords)):
        a.add_word(keywords[x], (x, keywords[x]))  # 第二个参数为自定义的返回值
# 创建 aho-corasick 自动机
a.make_automaton()
with open('jianjie.txt', 'r', encoding='utf-8') as f:  # 打开要检索文档
    jianjie = f.read()  # 读取正文(如果太多,可以分断加载,分段检索)
# 开始查找,该方法匹配最长的字符串
for item in a.iter_long(jianjie):
    print(item)
print('-' * 20)
# 开始查找,该方法匹配所有字符串
for item in a.iter(jianjie):
    print(item)

在上述示例中,首先创建了一个自动机对象 a,然后从文件中读取关键词,并使用 add_word 方法将关键词添加到自动机中。接着调用 make_automaton 方法创建 Aho-Corasick 自动机。最后,通过打开另一个文件读取要搜索的正文,并使用 iter_longiter 方法进行匹配查找,并打印出匹配的结果。

Aho-Corasick 自动机的优点包括能够在一次运行中找到给定集合所有字符串,适用于多模式字符串匹配的场景,例如网络内容过滤、版权检测、病毒扫描等,在自然语言处理中查找特定词汇或模式,以及生物信息学中在 DNA 或蛋白质序列分析中寻找特定的序列模式等方面都有应用。

到此这篇关于Python 多模式字符串搜索 Aho-Corasick详解的文章就介绍到这了,更多相关Python 多模式字符串搜索内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • python中如何打包用户自定义模块

    python中如何打包用户自定义模块

    在本篇文章里小编给大家整理的是一篇关于python中如何打包用户自定义模块的相关文章,有兴趣的朋友们可以参考下。
    2020-09-09
  • Python-OpenCV教程之图像的位运算详解

    Python-OpenCV教程之图像的位运算详解

    图像的位运算是指对图像的数值按照二进制值逐位进行取反、与、或、异或操作,本文就带大家了解相关知识,需要的朋友可以参考下
    2021-06-06
  • Atom的python插件和常用插件说明

    Atom的python插件和常用插件说明

    这篇文章给大家分享了Atom的python插件和常用插件,有需要的朋友们可以学习参考下。
    2018-07-07
  • Python安装Numpy和matplotlib的方法(推荐)

    Python安装Numpy和matplotlib的方法(推荐)

    下面小编就为大家带来一篇Python安装Numpy和matplotlib的方法(推荐)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-11-11
  • pandas 对series和dataframe进行排序的实例

    pandas 对series和dataframe进行排序的实例

    今天小编就为大家分享一篇pandas 对series和dataframe进行排序的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-06-06
  • 基于OpenCv实现的人脸识别(附Python完整代码)

    基于OpenCv实现的人脸识别(附Python完整代码)

    人脸识别是基于人的脸部特征信息进行身份识别的一种生物识别技术,下面这篇文章主要给大家介绍了关于如何基于OpenCv实现的人脸识别,文中还附Python完整代码,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-11-11
  • python中查找excel某一列的重复数据 剔除之后打印

    python中查找excel某一列的重复数据 剔除之后打印

    python查找excel某一列的重复数据,剔除之后打印,供大家学习参考
    2013-02-02
  • Python TensorFlow介绍与实战

    Python TensorFlow介绍与实战

    这篇文章介绍了Python TensorFlow介绍与实战,通过本文的介绍,我们不仅了解了TensorFlow的基本概念和安装方法,还通过线性回归和卷积神经网络的实例,深入探讨了 TensorFlow 的使用技巧,TensorFlow 的强大功能和灵活性使其成为深度学习领域的重要工具,需要的朋友可以参考下
    2024-07-07
  • python读取excel数据的详细教学

    python读取excel数据的详细教学

    在Python中读取Excel数据是一个常见的数据处理任务,本文主要为大家详细介绍了如何使用Python读取Excel数据,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下
    2026-01-01
  • 使用Django和Flask获取访问来源referrer

    使用Django和Flask获取访问来源referrer

    这篇文章主要介绍了使用Django和Flask获取访问来源referrer,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-04-04

最新评论