今天就跟大家聊聊有關(guān)使用python怎么實(shí)現(xiàn)一個(gè)文章敏感詞過(guò)濾功能,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
第一步:建立一個(gè)敏感詞庫(kù)(.txt文本)
第二步:編寫(xiě)代碼在文章中過(guò)濾敏感詞(遞歸實(shí)現(xiàn))
# -*- coding: utf-8 -*- # author 代序春秋 import os import chardet # 獲取文件目錄和絕對(duì)路徑 curr_dir = os.path.dirname(os.path.abspath(__file__)) # os.path.join()拼接路徑 sensitive_word_stock_path = os.path.join(curr_dir, 'sensitive_word_stock.txt') # 獲取存放敏感字庫(kù)的路徑 # print(sensitive_word_stock_path) class ArticleFilter(object): # 實(shí)現(xiàn)文章敏感詞過(guò)濾 def filter_replace(self, string): # string = string.decode("gbk") # 存放敏感詞的列表 filtered_words = [] # 打開(kāi)敏感詞庫(kù)讀取敏感字 with open(sensitive_word_stock_path) as filtered_words_txt: lines = filtered_words_txt.readlines() for line in lines: # strip() 方法用于移除字符串頭尾指定的字符(默認(rèn)為空格或換行符)或字符序列。 filtered_words.append(line.strip()) # 輸出過(guò)濾好之后的文章 print("過(guò)濾之后的文字:" + self.replace_words(filtered_words, string)) # 實(shí)現(xiàn)敏感詞的替換,替換為* def replace_words(self, filtered_words, string): # 保留新字符串 new_string = string # 從列表中取出敏感詞 for words in filtered_words: # 判斷敏感詞是否在文章中 if words in string: # 如果在則用*替換(幾個(gè)字替換幾個(gè)*) new_string = string.replace(words, "*" * len(words)) # 當(dāng)替換好的文章(字符串)與被替換的文章(字符串)相同時(shí),結(jié)束遞歸,返回替換好的文章(字符串) if new_string == string: # 返回替換好的文章(字符串) return new_string # 如果不相同則繼續(xù)替換(遞歸函數(shù)自己調(diào)用自己) else: # 遞歸函數(shù)自己調(diào)用自己 return self.replace_words(filtered_words, new_string) def main(): while True: string = input("請(qǐng)輸入一段文字:") run = ArticleFilter() run.filter_replace(string) continue if __name__ == '__main__': main()
運(yùn)行結(jié)果:
看完上述內(nèi)容,你們對(duì)使用python怎么實(shí)現(xiàn)一個(gè)文章敏感詞過(guò)濾功能有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。
本文名稱:使用python怎么實(shí)現(xiàn)一個(gè)文章敏感詞過(guò)濾功能-創(chuàng)新互聯(lián)
轉(zhuǎn)載來(lái)于:http://jinyejixie.com/article2/hipoc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供響應(yīng)式網(wǎng)站、網(wǎng)站收錄、手機(jī)網(wǎng)站建設(shè)、定制開(kāi)發(fā)、做網(wǎng)站、云服務(wù)器
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容