一種相似文本檢測裝置和方法
【專利摘要】本發(fā)明公開了一種相似文本檢測裝置和方法,用于識別相似文本,該裝置包括:中文文本獲取單元,適于對文本進(jìn)行文本處理以獲取中文文本;拼音文本獲取單元,適于將獲取的中文文本中的漢字轉(zhuǎn)為拼音得到拼音文本;指紋獲取單元,適于提取所述拼音文本的特征,將提取的特征形成所述拼音文本的特征向量;檢測單元,適于根據(jù)所述特征向量,判斷待檢測的文本是否與一個數(shù)據(jù)庫中的記錄匹配。使用本發(fā)明的裝置和方法,可以由待檢測的文本得到中文文本、進(jìn)而得到拼音文本、形成拼音文本的特征向量,以及根據(jù)特征向量判斷待檢測的文本是否與一個數(shù)據(jù)庫中的記錄匹配,達(dá)到降低運算量、準(zhǔn)確識別相似文本的變種的有益效果。
【專利說明】一種相似文本檢測裝置和方法
【技術(shù)領(lǐng)域】
[0001]本發(fā)明涉及計算機領(lǐng)域,具體涉及一種相似文本檢測裝置和方法。
【背景技術(shù)】
[0002]隨著問答社區(qū)等網(wǎng)絡(luò)應(yīng)用的興起,網(wǎng)絡(luò)上出現(xiàn)了大量的文本,比如用戶的提問和回答,然而大量的廣告信息充斥在網(wǎng)絡(luò)應(yīng)用中,給用戶查找信息帶來了諸多不便,同時也降低了網(wǎng)絡(luò)應(yīng)用的質(zhì)量。為了解決這個問題,文本相似度計算的研究工作逐漸開展起來,以期望能夠通過計算文本相似度找出廣告等垃圾信息。
[0003]—種相似文本檢測方法為:首先提取文本的特征(例如對文本進(jìn)行分詞,提取實體詞)并使用各種技術(shù)對特征進(jìn)行擴展(例如使用同義詞詞林,近義詞詞典等知識庫進(jìn)行詞匯擴展),并使用VSM模型來描述文本(例如使用VSM模型將一篇文本表示為一個向量),然后使用聚類方法對文本進(jìn)行聚類(例如對于兩篇文本,經(jīng)過向量化表示后,計算兩個向量的余弦夾角用于表征兩篇文本的相似性,如果相似度大于一定閾值,則認(rèn)為兩篇文本是相似的),被聚到一起的文本是相似的。
[0004]然而,在網(wǎng)絡(luò)應(yīng)用中,存在著大量的相似文本的變種,如使用繁體字、適用拼音代替文字、用同音字代替原字、加入大量無意義的干擾字符,等等,上述技術(shù)存在以下缺點:(一)分詞結(jié)果存在誤差;(二)同音不同字的文本無法判斷為相似;(三)無法將經(jīng)過拼音化處理的兩篇文本識別為相似文本;(四)對文本的計算復(fù)雜度太高(例如,將文本表示為向量,需要較大的運算量),無法滿足當(dāng)前大數(shù)據(jù)量情況下的運算實時性要求。
【發(fā)明內(nèi)容】
[0005]鑒于上述問題,提出了本發(fā)明以便提供一種克服上述問題或者至少部分地解決上述問題的一種相似文本檢測裝置和相應(yīng)的一種相似文本檢測方法。
[0006]依據(jù)本發(fā)明的一個方面,提供了 一種相似文本檢測裝置,其中,該裝置包括:
[0007]中文文本獲取單元,適于對文本進(jìn)行文本處理以獲取中文文本;
[0008]拼音文本獲取單元,適于將獲取的中文文本中的漢字轉(zhuǎn)為拼音得到拼音文本;
[0009]指紋獲取單元,適于提取所述拼音文本的特征,將提取的特征形成所述拼音文本的特征向量;
[0010]檢測單元,適于根據(jù)所述特征向量,判斷待檢測的文本是否與一個數(shù)據(jù)庫中的記錄匹配。
[0011]可選地,所述檢測單元,適于對所述特征向量中的每個特征,檢測數(shù)據(jù)庫中是否多次出現(xiàn)該特征;所述檢測單元,適于判斷所述特征向量中的在數(shù)據(jù)庫中多次出現(xiàn)的特征占該特征向量的全部特征的比例是否達(dá)到第一閾值,是則確定所述待檢測的文本與數(shù)據(jù)庫中的記錄匹配,否則不匹配。
[0012]可選地,所述檢測單元,適于對所述特征向量中的每個特征,從數(shù)據(jù)庫中查找是否存在該特征,如果存在,則進(jìn)一步查看該特征的權(quán)值,如果該特征的權(quán)值大于或等于第二閾值,則數(shù)據(jù)庫中多次出現(xiàn)該特征。
[0013]可選地,該裝置進(jìn)一步包括數(shù)據(jù)庫更新單元,所述數(shù)據(jù)庫更新單元,適于在確定所述待檢測的文本與數(shù)據(jù)庫中的記錄匹配時,對于所述特征向量中的每個特征,如果檢測到數(shù)據(jù)庫中存在該特征,則將數(shù)據(jù)庫中該特征的權(quán)值加I。
[0014]可選地,所述檢測單元,適于在對于所述特征向量中的每個特征,檢測數(shù)據(jù)庫中是否存在該特征之前,判斷所述特征向量中的特征的數(shù)目是否小于第三閾值,是則所述待檢測的文本與數(shù)據(jù)庫中的記錄不匹配并結(jié)束判斷操作,否則對于所述特征向量中的每個特征,檢測數(shù)據(jù)庫中是否多次出現(xiàn)該特征。
[0015]可選地,所述中文文本獲取單元,適于對文本進(jìn)行數(shù)據(jù)清洗操作,將文本中的內(nèi)容轉(zhuǎn)換為規(guī)則字符;將拼音轉(zhuǎn)化為漢字;以及保留常用的漢字。
[0016]可選地,所述中文文本獲取單元,適于識別并丟棄HTML標(biāo)記,將繁體字轉(zhuǎn)換為簡體字,將全角字符轉(zhuǎn)換為半角字符,將大寫英文字母轉(zhuǎn)換為小寫英文字母,以及識別并丟棄url,以將文本中的內(nèi)容轉(zhuǎn)換為規(guī)則字符;所述中文文本獲取單元,適于使用雙向最大匹配算法將文本中的拼音轉(zhuǎn)換為漢字,如果一個拼音對應(yīng)多個漢字,則從對應(yīng)的多個漢字中任選一個,以將文本中的拼音轉(zhuǎn)化為漢字;所述中文文本獲取單元,適于使用GBK編碼表中的常用漢字對文本進(jìn)行過濾,丟棄所有不屬于常用漢字的字符,以保留常用的漢字。
[0017]可選地,所述拼音文本獲取單元,適于使用拼音漢字對照表,將每個漢字轉(zhuǎn)換為對應(yīng)的拼音串,以得到拼音文本。
[0018]可選地,所述指紋獲取單元,適于以單個漢字為切分粒度提取所述拼音文本的特征,并使用向量空間模型將提取的特征形成所述拼音文本的特征向量。
[0019]根據(jù)本發(fā)明的另一方面,提供了一種相似文本檢測方法,其中,該方法包括如下步驟:
[0020]對待檢測的文本進(jìn)行文本處理以獲取中文文本;
[0021]將獲取的中文文本中的漢字轉(zhuǎn)為拼音得到拼音文本;
[0022]提取所述拼音文本的特征,將提取的特征形成所述拼音文本的特征向量;
[0023]根據(jù)所述特征向量,判斷待檢測的文本是否與一個數(shù)據(jù)庫中的記錄匹配。
[0024]可選地,所述判斷待檢測的文本是否與數(shù)據(jù)庫中的記錄匹配包括:對所述特征向量中的每個特征,檢測數(shù)據(jù)庫中是否多次出現(xiàn)該特征;判斷所述特征向量中的在數(shù)據(jù)庫中多次出現(xiàn)的特征占該特征向量的全部特征的比例是否達(dá)到第一閾值,是則確定所述待檢測的文本與數(shù)據(jù)庫中的記錄匹配,否則不匹配。
[0025]可選地,所述檢測數(shù)據(jù)庫中是否多次出現(xiàn)該特征包括:從數(shù)據(jù)庫中查找是否存在該特征,如果存在,則進(jìn)一步查看該特征的權(quán)值,如果該特征的權(quán)值大于或等于第二閾值,則數(shù)據(jù)庫中多次出現(xiàn)該特征。
[0026]可選地,在確定所述待檢測的文本與數(shù)據(jù)庫中的記錄匹配時,該方法進(jìn)一步包括:對于所述特征向量中的每個特征,如果檢測到數(shù)據(jù)庫中存在該特征,則該將數(shù)據(jù)庫中該特征的權(quán)值加I。
[0027]可選地,在對于所述特征向量中的每個特征,檢測數(shù)據(jù)庫中是否存在該特征之前,所述判斷待檢測的文本是否與數(shù)據(jù)庫中的記錄匹配進(jìn)一步包括:判斷所述特征向量中的特征的數(shù)目是否小于第三閾值,是則所述待檢測的文本與數(shù)據(jù)庫中的記錄不匹配并結(jié)束判斷操作,否則對于所述特征向量中的每個特征,檢測數(shù)據(jù)庫中是否多次出現(xiàn)該特征。
[0028]可選地,所述對文本進(jìn)行文本處理以獲取中文文本,具體包括:對文本進(jìn)行數(shù)據(jù)清洗操作,將文本中的內(nèi)容轉(zhuǎn)換為規(guī)則字符;將拼音轉(zhuǎn)化為漢字;保留常用的漢字。
[0029]可選地,所述對文本進(jìn)行數(shù)據(jù)清洗操作,具體包括:識別并丟棄HTML標(biāo)記,將繁體字轉(zhuǎn)換為簡體字,將全角字符轉(zhuǎn)換為半角字符,將大寫英文字母轉(zhuǎn)換為小寫英文字母,以及識別并丟棄url ;所述將文本中的拼音轉(zhuǎn)化為漢字,具體包括:使用雙向最大匹配算法將文本中的拼音轉(zhuǎn)換為漢字,如果一個拼音對應(yīng)多個漢字,則從對應(yīng)的多個漢字中任選一個;所述保留常用的漢字,具體包括:使用GBK編碼表中的常用漢字對文本進(jìn)行過濾,丟棄所有不屬于常用漢字的字符。
[0030]可選地,所述將獲取的中文文本中的漢字轉(zhuǎn)為拼音得到拼音文本,具體包括:使用拼音漢字對照表,將每個漢字轉(zhuǎn)換為對應(yīng)的拼音串,得到拼音文本。
[0031]可選地,所述提取所述拼音文本的特征,將提取的特征形成所述拼音文本的特征向量,具體包括:以單個漢字為切分粒度提取所述拼音文本的特征,并使用向量空間模型將提取的特征形成所述拼音文本的特征向量。
[0032]根據(jù)本發(fā)明的相似文本檢測裝置和方法,可以由待檢測的文本得到中文文本、進(jìn)而得到拼音文本、形成所述拼音文本的特征向量,以及根據(jù)所述特征向量判斷待檢測的文本是否與一個數(shù)據(jù)庫中的記錄匹配,解決了【背景技術(shù)】運算量大、不能有效識別相似文本的變種的問題,取得了降低運算量、準(zhǔn)確識別相似文本的變種的有益效果。
[0033]上述說明僅是本發(fā)明技術(shù)方案的概述,為了能夠更清楚了解本發(fā)明的技術(shù)手段,而可依照說明書的內(nèi)容予以實施,并且為了讓本發(fā)明的上述和其它目的、特征和優(yōu)點能夠更明顯易懂,以下特舉本發(fā)明的【具體實施方式】。
【專利附圖】
【附圖說明】
[0034]通過閱讀下文優(yōu)選實施方式的詳細(xì)描述,各種其他的優(yōu)點和益處對于本領(lǐng)域普通技術(shù)人員將變得清楚明了。附圖僅用于示出優(yōu)選實施方式的目的,而并不認(rèn)為是對本發(fā)明的限制。而且在整個附圖中,用相同的參考符號表示相同的部件。在附圖中:
[0035]圖1示出了根據(jù)本發(fā)明一個實施例的相似文本檢測方法的流程圖;
[0036]圖2示出了如圖1所示的步驟S100、步驟S200和步驟S300的詳細(xì)的流程圖;
[0037]圖3示出了如圖1所示的步驟S400的詳細(xì)的流程圖;
[0038]圖4示出了根據(jù)本發(fā)明第一實施例的相似文本檢測裝置的框圖;以及
[0039]圖5示出了根據(jù)本發(fā)明第二實施例的相似文本檢測裝置的框圖。
【具體實施方式】
[0040]下面將參照附圖更詳細(xì)地描述本公開的示例性實施例。雖然附圖中顯示了本公開的示例性實施例,然而應(yīng)當(dāng)理解,可以以各種形式實現(xiàn)本公開而不應(yīng)被這里闡述的實施例所限制。相反,提供這些實施例是為了能夠更透徹地理解本公開,并且能夠?qū)⒈竟_的范圍完整的傳達(dá)給本領(lǐng)域的技術(shù)人員。
[0041]圖1示出了根據(jù)本發(fā)明一個實施例的相似文本檢測方法的流程圖。圖2示出了圖1中步驟S100、步驟S200和步驟S300的詳細(xì)的流程圖。該方法包括以下的步驟S100、S200、S300 和 S400。
[0042]S100、對待檢測的文本進(jìn)行文本處理以獲取中文文本。
[0043]通過由待檢測的文本獲取中文文本,可以消除包括有無意義的干擾字符、繁體字等相似文本的變種對本實施例相似文本檢測方法的影響。
[0044]S200、將獲取的中文文本中的漢字轉(zhuǎn)為拼音得到拼音文本。
[0045]通過將中文文本中的漢字統(tǒng)一轉(zhuǎn)化為拼音,可以消除用拼音代替文字、用同音字代替原字等相似文本的變種對本實施例相似文本檢測方法的影響。
[0046]S300、提取所述拼音文本的特征,將提取的特征形成所述拼音文本的特征向量。
[0047]本實施例中,可以采用N元語言模型(N-gram)提起拼音文本的特征向量,基于步驟SlOO獲取的中文文本中的漢字粒度,對步驟S200獲取的拼音文本提取N-gram特征SHINGLE^ SHINGLE^…SHINGLEm。例如,如果步驟SlOO獲取的中文文本為“我愛北京天安門”,漢字粒度為“我”、“愛”、“北”、“京”、“天”,“安”,“門”,步驟S200獲取的拼音文本為“wo ai bei jing tian an 111611”,那么拼音串被切分為“¥0”、“&;[”、%6;[”、“」;[1^”、“1:1&11”、“an”、“men”,如果令 N=6 則步驟 S300 中,獲取的 N-gram 特征 SHINGLei 為“wo ai bei jingtian an”、SHINGLe2 為“ai bei jing tian an men”,依次類推。并使用向量空間模型(VSM,Vector Space Model)形成特征向量 DMSHINGLEi, SHINGLE2,…,SHINGLEJ。
[0048]S400、根據(jù)所述特征向量,判斷待檢測的文本是否與一個數(shù)據(jù)庫中的記錄匹配。
[0049]本實施例中,對 每一個特征,會檢測在一個預(yù)設(shè)的數(shù)據(jù)庫中是否多次出現(xiàn)該特征。檢測了一個特征向量中的所有特征之后,判斷特征向量中的在數(shù)據(jù)庫中多次出現(xiàn)的特征占特征向量的全部特征的比例,從而判斷待檢測的文本與數(shù)據(jù)庫中的記錄是否匹配。本實施例中預(yù)設(shè)的數(shù)據(jù)庫使用Redis數(shù)據(jù)庫,可以是通過對海量的網(wǎng)絡(luò)文本(例如抓取收集的網(wǎng)絡(luò)廣告等垃圾信息)進(jìn)行分析得到海量的特征,并統(tǒng)計得到的各個特征的數(shù)目而得到權(quán)值,令特征(Shingle)和權(quán)值(Value)構(gòu)成數(shù)據(jù)庫。
[0050]圖2示出了圖1中步驟S100、步驟S200和步驟S300的詳細(xì)的流程圖。步驟SlOO具體包括:
[0051]S110、對文本進(jìn)行數(shù)據(jù)清洗操作,將文本中的內(nèi)容轉(zhuǎn)換為規(guī)則字符。
[0052]其中,對文本進(jìn)行數(shù)據(jù)清洗操作,具體包括:識別并丟棄HTML標(biāo)記,將繁體字轉(zhuǎn)換為簡體字,將全角字符轉(zhuǎn)換為半角字符,將大寫英文字母轉(zhuǎn)換為小寫英文字母,以及識別并丟棄url。
[0053]S120、將拼音轉(zhuǎn)化為漢字。
[0054]其中,將文本中的拼音轉(zhuǎn)化為漢字,具體包括:使用雙向最大匹配算法將文本中的拼音轉(zhuǎn)換為漢字,如果一個拼音對應(yīng)多個漢字,則從對應(yīng)的多個漢字中任選一個。
[0055]S130、保留常用的漢字。
[0056]其中,保留常用的漢字,具體包括:使用GBK編碼表中的常用漢字對文本進(jìn)行過濾,丟棄所有不屬于常用漢字的字符,即只保留漢字GBK編碼在OxBOAO~0xF7FE中的漢字。
[0057]步驟S200具體包括:使用拼音漢字對照表,將每個漢字轉(zhuǎn)換為對應(yīng)的拼音串,得到拼音文本。
[0058]通過步驟SlOO由待檢測的文本獲取中文文本,以及通過步驟S200將獲取的中文文本中的漢字轉(zhuǎn)為拼音得到拼音文本,可以將相似文本的不同變種,識別為相同的拼音文本。例如將如表1所示的文本和三種變種,通過步驟SlOO和S200得到相同的拼音文本。
[0059]表1文本及三種變種
[0060]
【權(quán)利要求】
1.一種相似文本檢測裝置,其中,該裝置包括: 中文文本獲取單元,適于對文本進(jìn)行文本處理以獲取中文文本; 拼音文本獲取單元,適于將獲取的中文文本中的漢字轉(zhuǎn)為拼音得到拼音文本; 指紋獲取單元,適于提取所述拼音文本的特征,將提取的特征形成所述拼音文本的特征向量; 檢測單元,適于根據(jù)所述特征向量,判斷待檢測的文本是否與一個數(shù)據(jù)庫中的記錄匹配。
2.根據(jù)權(quán)利要求1所述的裝置,其中, 所述檢測單元,適于對所述特征向量中的每個特征,檢測數(shù)據(jù)庫中是否多次出現(xiàn)該特征; 所述檢測單元,適于判斷所述特征向量中的在數(shù)據(jù)庫中多次出現(xiàn)的特征占該特征向量的全部特征的比例是否達(dá)到第一閾值,是則確定所述待檢測的文本與數(shù)據(jù)庫中的記錄匹配,否則不匹配。
3.根據(jù)權(quán)利要求1或2所述的裝置,其中, 所述檢測單元,適于 對所述特征向量中的每個特征,從數(shù)據(jù)庫中查找是否存在該特征,如果存在,則進(jìn)一步查看該特征的權(quán)值,如果該特征的權(quán)值大于或等于第二閾值,則數(shù)據(jù)庫中多次出現(xiàn)該特征。
4.根據(jù)權(quán)利要求1-3任一項所述的裝置,其中,該裝置進(jìn)一步包括數(shù)據(jù)庫更新單元, 所述數(shù)據(jù)庫更新單元,適于在確定所述待檢測的文本與數(shù)據(jù)庫中的記錄匹配時,對于所述特征向量中的每個特征,如果檢測到數(shù)據(jù)庫中存在該特征,則將數(shù)據(jù)庫中該特征的權(quán)值加I。
5.根據(jù)權(quán)利要求1-4任一項所述的裝置,其中, 所述檢測單元,適于在對于所述特征向量中的每個特征,檢測數(shù)據(jù)庫中是否存在該特征之前,判斷所述特征向量中的特征的數(shù)目是否小于第三閾值,是則所述待檢測的文本與數(shù)據(jù)庫中的記錄不匹配并結(jié)束判斷操作,否則對于所述特征向量中的每個特征,檢測數(shù)據(jù)庫中是否多次出現(xiàn)該特征。
6.一種相似文本檢測方法,其中,該方法包括如下步驟: 對待檢測的文本進(jìn)行文本處理以獲取中文文本; 將獲取的中文文本中的漢字轉(zhuǎn)為拼音得到拼音文本; 提取所述拼音文本的特征,將提取的特征形成所述拼音文本的特征向量; 根據(jù)所述特征向量,判斷待檢測的文本是否與一個數(shù)據(jù)庫中的記錄匹配。
7.根據(jù)權(quán)利要求6所述的方法,其中,所述判斷待檢測的文本是否與數(shù)據(jù)庫中的記錄匹配包括: 對所述特征向量中的每個特征,檢測數(shù)據(jù)庫中是否多次出現(xiàn)該特征; 判斷所述特征向量中的在數(shù)據(jù)庫中多次出現(xiàn)的特征占該特征向量的全部特征的比例是否達(dá)到第一閾值,是則確定所述待檢測的文本與數(shù)據(jù)庫中的記錄匹配,否則不匹配。
8.根據(jù)權(quán)利要求6或7所述的方法,其中,所述檢測數(shù)據(jù)庫中是否多次出現(xiàn)該特征包括: 從數(shù)據(jù)庫中查找是否存在該特征,如果存在,則進(jìn)一步查看該特征的權(quán)值,如果該特征的權(quán)值大于或等于第二閾值,則數(shù)據(jù)庫中多次出現(xiàn)該特征。
9.根據(jù)權(quán)利要求6-8任一項所述的方法,其中,在確定所述待檢測的文本與數(shù)據(jù)庫中的記錄匹配時,該方法進(jìn)一步包括: 對于所述特征向量中的每個特征,如果檢測到數(shù)據(jù)庫中存在該特征,則該將數(shù)據(jù)庫中該特征的權(quán)值加I。
10.根據(jù)權(quán)利要求6-9任一項所述的方法,其中, 在對于所述特征向量中的每個特征,檢測數(shù)據(jù)庫中是否存在該特征之前,所述判斷待檢測的文本是否與數(shù)據(jù)庫中的記錄匹配進(jìn)一步包括: 判斷所述特征向量中的特征的數(shù)目是否小于第三閾值,是則所述待檢測的文本與數(shù)據(jù)庫中的記錄不匹配并結(jié)束判斷操作,否則對于所述特征向量中的每個特征,檢測數(shù)據(jù)庫中是否多次出現(xiàn)該特征。
【文檔編號】G06F17/30GK103605694SQ201310537965
【公開日】2014年2月26日 申請日期:2013年11月4日 優(yōu)先權(quán)日:2013年11月4日
【發(fā)明者】孫林, 陳培軍, 秦吉勝 申請人:北京奇虎科技有限公司, 奇智軟件(北京)有限公司