av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

算法 - python ahocorasick 從本地文件讀取文本,進行關鍵字匹配,匹配失敗

瀏覽:108日期:2022-07-23 09:06:00

問題描述

使用Python+pyahocorasick,匹配關鍵字,關鍵字大概在10-20個漢字之間。

構建ahocorasick的文本,是從本地文件key_word的讀入。格式如下:

母嬰專區<輔食<面仔/面條:嬰幼兒,幼兒,嬰兒,兒童,寶寶面條,細面,粗面,手工面,蔬菜面,營養面,碎面,掛面,面仔

匹配結果為空。

代碼如下:

import ahocorasickA = ahocorasick.Automaton()title = ’Hello Kitty3色蔬菜細面300克 嬰兒幼兒營養面條寶寶輔食面條’with open(’key_word’, ’r’) as f: for line in f.readlines():line = line.strip()line = str(line.split(’<’)) A.add_word(line, line)A.make_automaton()aa = A.iter(title)for item in aa: print(item) # 打印為空值

請有操作過這種問題的大大,幫忙看看,能提供示例代碼,或者提供處理思路,謝謝!

問題解答

回答1:

研究了兩天,自己實現了這個功能

本地文件有太多重復關鍵字,匹配并不是100%,供參考

參考代碼如下:

import ahocorasickA = ahocorasick.Automaton()titles = [’Hello Kitty3色蔬菜細面300克 嬰兒幼兒營養面條寶寶輔食面條’]word_dict = {}with open(’categories.csv’, ’r’) as f: for line in f.readlines():line = line.strip()word_key = line.split(’:’)[0]word_value = list(line.split(’:’)[1].split(’|’))word_dict[word_key] = word_valueline = (line.split(’:’)[1].split(’|’))for word in line: if word == '':continue A.add_word(word, word)A.make_automaton()for title in titles: category = [] aa = A.iter(title) ret = [] matches = {} for (k,v) in aa:matches[v] = 1 for (k,v) in matches.items():ret.append(k) for value in word_dict.items():if ret[0] in value[1]: category.append(value[0]) #關鍵字太多,所以寫死了一個keyword匹配的結果 #print(ret[0], value[0], value[1]) print(category[0])

打印結果:母嬰專區<輔食<面仔/面條

標簽: Python 編程
主站蜘蛛池模板: 国产欧美精品一区二区三区 | 老司机午夜免费精品视频 | 亚洲一级在线 | 一区二区日韩 | 色婷婷基地 | 亚洲激情综合 | 午夜黄视频 | 日本视频免费观看 | 免费一区二区三区 | 黄色国产视频 | 亚洲九九夜夜 | 国产精品无遮挡 | 高清视频一区二区 | 欧美人与性动交α欧美精品 | 亚洲aaa| 特一级黄色片 | 美日韩丰满少妇在线观看 | 中文字幕一区在线观看 | 亚洲精品视频免费在线观看 | 国产人成 | 国产亚洲欧美日韩高清 | 欧美a在线 | 最新av在线播放 | 国产免费av在线 | 欧美精品一区二区三区四区 | 日本黄色免费看 | 伊人91| 成人激情视频在线观看 | 少妇视频在线观看 | 日本a级大片 | www一级片| 97青青草 | 国产91清纯白嫩初高中在线观看 | 日韩欧美国产成人 | 黄色a一级 | 一区二区不卡 | 日韩精品一区在线 | 成年网站在线观看 | 中文字幕在线观看日本 | 日本福利在线 | 久久麻豆视频 |