亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > Python容錯的前綴樹實現中文糾錯

Python容錯的前綴樹實現中文糾錯

熱門標簽:電銷機器人錄音要學習什么 煙臺電話外呼營銷系統 如何地圖標注公司 預覽式外呼系統 銀川電話機器人電話 企業彩鈴地圖標注 上海正規的外呼系統最新報價 外賣地址有什么地圖標注 長春極信防封電銷卡批發

介紹

本文使用 Python 實現了前綴樹,并且支持編輯距離容錯的查詢。文中的前綴樹只存儲了三個分詞,格式為 (分詞字符串,頻率) ,如:('中海晉西園', 2)、('中海西園', 24)、('中南海', 4),可以換成自己的文件進行數據的替換。在查詢的時候要指定一個字符串和最大的容錯編輯距離。

實現

class Word:
    def __init__(self, word, freq):
        self.word = word
        self.freq = freq

class Trie:
    def __init__(self):
        self.root = LetterNode('')
        self.START = 3

    def insert(self, word, freq):
        self.root.insert(word, freq, 0)

    def findAll(self, query, maxDistance):
        suggestions = self.root.recommend(query, maxDistance, self.START)
        return sorted(set(suggestions), key=lambda x: x.freq)


class LetterNode:
    def __init__(self, char):
        self.REMOVE = -1
        self.ADD = 1
        self.SAME = 0
        self.CHANGE = 2
        self.START = 3
        self.pointers = []
        self.char = char
        self.word = None

    def charIs(self, c):
        return self.char == c

    def insert(self, word, freq, depth):
        if ' ' in word:
            word = [i for i in word.split(' ')]
        if depth  len(word):
            c = word[depth].lower()
            for next in self.pointers:
                if next.charIs(c):
                    return next.insert(word, freq, depth + 1)
            nextNode = LetterNode(c)
            self.pointers.append(nextNode)
            return nextNode.insert(word, freq, depth + 1)
        else:
            self.word = Word(word, freq)

    def recommend(self, query, movesLeft, lastAction):
        suggestions = []
        length = len(query)

        if length >= 0 and movesLeft - length >= 0 and self.word:
            suggestions.append(self.word)

        if movesLeft == 0 and length > 0:
            for next in self.pointers:
                if next.charIs(query[0]):
                    suggestions += next.recommend(query[1:], movesLeft, self.SAME)
                    break

        elif movesLeft > 0:
            for next in self.pointers:
                if length > 0:
                    if next.charIs(query[0]):
                        suggestions += next.recommend(query[1:], movesLeft, self.SAME)
                    else:
                        suggestions += next.recommend(query[1:], movesLeft - 1, self.CHANGE)
                        if lastAction != self.CHANGE and lastAction != self.REMOVE:
                            suggestions += next.recommend(query, movesLeft - 1, self.ADD)
                        if lastAction != self.ADD and lastAction != self.CHANGE:
                            if length > 1 and next.charIs(query[1]):
                                suggestions += next.recommend(query[2:], movesLeft - 1, self.REMOVE)
                            elif length > 2 and next.charIs(query[2]) and movesLeft == 2:
                                suggestions += next.recommend(query[3:], movesLeft - 2, self.REMOVE)
                else:
                    if lastAction != self.CHANGE and lastAction != self.REMOVE:
                        suggestions += next.recommend(query, movesLeft - 1, self.ADD)
        return suggestions



def buildTrieFromFile():
    trie = Trie()
    rows = [('中海晉西園', 2),('中海西園', 24),('中南海', 4)]
    for row in rows:
        trie.insert(row[0], int(row[1]))
    return trie


def suggestor(trie, s, maxDistance):
    if ' ' in s:
        s = [x for x in s.split(' ')]
    suggestions = trie.findAll(s, maxDistance)
    return [str(x.word) for x in suggestions]


if __name__ == "__main__":
    trie = buildTrieFromFile()
    r = suggestor(trie, '中海晉西園', 1)
    print(r)

分析

結果打印:
['中海晉西園', '中海西園']

可以看出“中海晉西園”是和輸入完全相同的字符串,編輯距離為 0 ,所以符合最大編輯距離為 1 的要求,直接返回。

“中海西園”是“中海晉西園”去掉“晉”字之后的結果,編輯距離為 1, 所以符合最大編輯距離為 1 的要求,直接返回。

另外,“中南海”和“中海晉西園”的編輯距離為 4 ,不符合最大編輯距離為 1 的要求,所以結果中沒有出現。

參考

https://github.com/leoRoss/AutoCorrectTrie

到此這篇關于Python容錯的前綴樹實現中文糾錯的文章就介紹到這了,更多相關Python 中文糾錯內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Python中文糾錯的簡單實現

標簽:潮州 宜昌 佳木斯 西寧 上饒 湖北 珠海 盤錦

巨人網絡通訊聲明:本文標題《Python容錯的前綴樹實現中文糾錯》,本文關鍵詞  Python,容,錯的,前綴,樹,實現,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Python容錯的前綴樹實現中文糾錯》相關的同類信息!
  • 本頁收集關于Python容錯的前綴樹實現中文糾錯的相關信息資訊供網民參考!
  • 推薦文章
    麻豆污视频| 亚欧视频在线| 日日夜人人澡人人澡人人看免| 亚久久伊人精品青青草原2020| 午夜在线影院| 久久精品免视看国产成人2021| 国产一区二区精品久久| 精品国产香蕉伊思人在线又爽又黄| 欧美爱爱网| 亚久久伊人精品青青草原2020| 日韩免费在线| 九九干| 国产伦精品一区三区视频| 国产a一级| 国产一区精品| 精品视频在线观看一区二区| 高清一级淫片a级中文字幕| 日日日夜夜操| 99久久视频| 国产91丝袜高跟系列| 欧美电影免费看大全| 日韩欧美一及在线播放| 国产麻豆精品| 久久精品人人做人人爽97| 国产网站免费观看| 亚洲精品中文字幕久久久久久| 亚久久伊人精品青青草原2020| 日韩中文字幕在线亚洲一区 | 色综合久久天天综线观看| 亚洲精品中文一区不卡| 欧美日本免费| 999久久66久6只有精品| 日本在线不卡视频| 国产综合成人观看在线| 精品国产一级毛片| 国产一区二区精品在线观看| 99热精品在线| 四虎影视久久久| 毛片高清| 国产91素人搭讪系列天堂| 欧美1区| 麻豆网站在线看| 免费一级片在线| 一级毛片视频播放| 国产a视频精品免费观看| 成人a级高清视频在线观看| 九九久久国产精品| 成人免费一级毛片在线播放视频| 国产高清视频免费| 毛片电影网| 国产美女在线观看| 国产麻豆精品高清在线播放| 日日夜人人澡人人澡人人看免| 欧美激情一区二区三区在线 | 日韩男人天堂| 999久久久免费精品国产牛牛| 国产精品免费久久| 999精品视频在线| 国产网站免费视频| 久草免费在线视频| 日韩av成人| 日韩综合| 国产视频久久久久| 青青久在线视频| 免费国产一级特黄aa大片在线| 美女免费毛片| 91麻豆精品国产高清在线| 国产网站在线| 在线观看成人网 | 日韩专区在线播放| 国产91丝袜在线播放0| 日韩中文字幕在线亚洲一区 | 欧美18性精品| 一 级 黄 中国色 片| 成人a大片高清在线观看| 日韩在线观看免费完整版视频| 成人高清视频在线观看| 久久精品成人一区二区三区| 999久久狠狠免费精品| 中文字幕97| 日韩中文字幕一区二区不卡| 深夜做爰性大片中文| 成人免费观看的视频黄页| 色综合久久天天综线观看| 久久久久久久免费视频| 日韩在线观看视频黄| 免费一级片在线| 你懂的日韩| 青青青草影院| 久久国产影院| 国产网站在线| 国产一区精品| 国产视频久久久久| 欧美激情影院| 精品国产一区二区三区久| 亚洲 欧美 成人日韩| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 九九久久国产精品| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 欧美电影免费| 国产一级生活片| 亚洲精品永久一区| 午夜精品国产自在现线拍| 日韩专区亚洲综合久久| 韩国毛片| 久久国产一久久高清| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 欧美1区2区3区| 日韩中文字幕在线亚洲一区 | 免费的黄色小视频| 午夜欧美成人香蕉剧场| 人人干人人草| 国产国语对白一级毛片| 久久成人综合网| 亚欧成人乱码一区二区| 国产不卡高清在线观看视频| 天堂网中文在线| 四虎影视久久| 午夜激情视频在线观看 | 精品国产三级a∨在线观看| 国产综合91天堂亚洲国产| 欧美另类videosbestsex视频| 毛片电影网| 色综合久久天天综合绕观看| 可以免费在线看黄的网站| 欧美另类videosbestsex高清| 99久久视频| 九九久久99| 日本免费看视频| 午夜欧美成人香蕉剧场| 亚洲女人国产香蕉久久精品| 999久久66久6只有精品| 色综合久久天天综合| 欧美a级大片| 日韩在线观看免费完整版视频| 久久精品成人一区二区三区| 夜夜操天天爽| 国产91丝袜高跟系列| 久草免费在线视频| 久久精品店| 久草免费在线色站| 四虎影视久久久| 麻豆系列 在线视频| 97视频免费在线观看| 国产一级强片在线观看| 你懂的国产精品| 国产视频久久久久| 国产精品自拍一区| 成人高清视频免费观看| 日本特黄特黄aaaaa大片| 国产麻豆精品免费密入口| 精品国产亚洲人成在线| 日韩av东京社区男人的天堂| 黄色短视频网站| 亚洲第一页色| 99久久精品国产国产毛片| 天天色成人| 久久99这里只有精品国产| 久草免费在线色站| 99久久精品国产免费| 欧美激情一区二区三区中文字幕| 国产伦精品一区三区视频| 国产高清在线精品一区a| 成人免费一级纶理片| 黄色免费网站在线| 国产不卡高清| 日本特黄一级| 黄色福利| 精品久久久久久综合网| 国产成人欧美一区二区三区的| 国产一区精品| 日韩免费在线视频| 国产精品自拍在线观看| 一级女性全黄生活片免费| 国产综合91天堂亚洲国产| 国产麻豆精品高清在线播放| 成人av在线播放| 99久久网站| 久久国产精品只做精品| 一 级 黄 中国色 片| 国产一区二区精品久久91| 国产精品123| 999精品视频在线| 久久精品成人一区二区三区| 久久久成人网| 日韩男人天堂| 精品国产一区二区三区久| 午夜在线影院| 精品国产一区二区三区久| 国产一区二区精品尤物| 国产成人欧美一区二区三区的| 黄视频网站免费看| 国产美女在线一区二区三区| 精品视频一区二区三区免费| 国产91素人搭讪系列天堂| 国产视频久久久| 91麻豆精品国产高清在线| 国产麻豆精品免费密入口| 天天色色色| 在线观看成人网|