Qt實(shí)現(xiàn)模糊匹配功能的實(shí)例詳解
對(duì)于瀏覽器的使用,我想大家一定不會(huì)陌生吧,輸入要搜索的內(nèi)容時(shí),會(huì)出現(xiàn)相應(yīng)的匹配信息。
那么,今天我要講述的也是這樣一個(gè)功能。
首先看一下展示效果

輸入任意文本后,彈出具有該文本的符合項(xiàng),也就是模糊查詢。
實(shí)現(xiàn)功能的核心是:QCompleter
該類(lèi)可以在任何Qt小部件中提供自動(dòng)完成搜索功能,例如:QLineEdit、QComboBox。當(dāng)輸入指定字符后,QCompleter會(huì)根據(jù)單詞列表提供的內(nèi)容進(jìn)行篩查。
在這里,我是采用QLineEdit + QCompleter組合使用的。
下面我來(lái)介紹下如何使用的吧~
1.準(zhǔn)備基礎(chǔ)數(shù)據(jù)
想要讓QCompleter完成模糊匹配功能,前提必須要有一個(gè)可供查詢的庫(kù)文件,否則是無(wú)法搜索的。
這里就簡(jiǎn)單插入一些字符串吧~
QStringList listData;
listData << QStringLiteral("基礎(chǔ)數(shù)據(jù)1");
listData << QStringLiteral("基礎(chǔ)數(shù)據(jù)n");
2.創(chuàng)建并實(shí)例化匹配類(lèi)
QCompleter *m_pCompleter = new QCompleter(listData);
設(shè)置匹配方式,在Completer中存在以下幾種匹配模式,分別列舉,如下:
| 模式 | 描述 |
|---|---|
| Qt::MatchExactly | 只匹配第一個(gè)字/詞 |
| Qt::MatchFixedString | 只匹配第一個(gè)詞,并且區(qū)分大小寫(xiě) |
| Qt::MatchContains | 只要字符串中包含字/詞就能匹配 |
| Qt::MatchStartsWith | 與第一個(gè)字/詞進(jìn)行匹配 |
| Qt::MatchEndsWith | |
| Qt::MatchCaseSensitive | 搜索區(qū)分大小寫(xiě) |
| Qt::MatchRegExp | 使用正則表達(dá)式作為搜索項(xiàng)執(zhí)行基于字符串的匹配(Qt5.15) |
| Qt::MatchRegularExpression | 使用正則表達(dá)式作為搜索項(xiàng)執(zhí)行基于字符串的匹配(Qt5.15) |
| Qt::MatchWildcard | 使用帶有通配符的字符串作為搜索條件,執(zhí)行基于字符串的匹配 |
| Qt::MatchWrap | 執(zhí)行一個(gè)環(huán)繞的搜索,這樣當(dāng)搜索到達(dá)模型中的最后一項(xiàng)時(shí),就會(huì)從第一個(gè)項(xiàng)開(kāi)始,直到檢查完所有項(xiàng)為止 |
| Qt::MatchRecursive | 搜索整個(gè)層次結(jié)構(gòu) |
在使用過(guò)程中,一般采用:Qt::MatchContains的定義比較多。
代碼設(shè)置,如下:
m_pCompleter->setFilterMode(Qt::MatchContains);
3.控件綁定
ui.edit->setCompleter(m_pCompleter);
到此,一個(gè)簡(jiǎn)單的模糊搜索就實(shí)現(xiàn)了,其實(shí)在使用過(guò)程中為了美觀起見(jiàn),還可以對(duì)QCompleter中展示的文本進(jìn)行美化~
例如:
滾動(dòng)條風(fēng)格
QString g_scrollVerticalWidth8Gray =
"QScrollBar:vertical{ width:8px; background-color:#e9f1f7;}"
"QScrollBar::handle:vertical{ width:8px; background-color:#6eade0; border-radius:4px;}"
"QScrollBar::handle:vertical:hover{background-color:#2b76af;}"
"QScrollBar::handle:vertical:pressed{background-color:#1e659b;}";
Completer風(fēng)格
QString qsCompleterStyle =
//設(shè)置:背景色、字體顏色、大小、字體風(fēng)格
"QAbstractItemView{background-color:#FFFFFF;color: #FFB6C1;font-size:16px;font-family:Microsoft YaHei UI;outline:0px;}"
"QAbstractItemView::item:hover{background-color:#7FFF00;color: #0000FF;}"
"QAbstractItemView::item:selected{background-color:#FF8C00;color: #0000FF;}";
風(fēng)格設(shè)置,如下:
m_pCompleter->popup()->setStyleSheet(qsCompleterStyle + g_scrollVerticalWidth8Gray);
單純的設(shè)置風(fēng)格肯定是不行的,想要讓風(fēng)格有效,必須設(shè)置:QStyledItemDelegate
QStyledItemDelegate *d = new QStyledItemDelegate; m_completerName->popup()->setItemDelegate(d);
最終展示效果,如下:

到此這篇關(guān)于Qt實(shí)現(xiàn)模糊匹配功能的實(shí)例詳解的文章就介紹到這了,更多相關(guān)Qt模糊匹配功能內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
實(shí)現(xiàn)Dijkstra算法最短路徑問(wèn)題詳解
這篇文章主要介紹了實(shí)現(xiàn)Dijkstra算法最短路徑問(wèn)題詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08
C++關(guān)于/2和>>1的區(qū)別說(shuō)明
這篇文章主要介紹了C++關(guān)于/2和>>1的區(qū)別說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07
形參出現(xiàn)在函數(shù)定義中,在整個(gè)函數(shù)體內(nèi)都可以使用, 離開(kāi)該函數(shù)則不能使用。實(shí)參出現(xiàn)在主調(diào)函數(shù)中,進(jìn)入被調(diào)函數(shù)后,實(shí)參變量也不能使用,形參和實(shí)參的功能是作數(shù)據(jù)傳送。發(fā)生函數(shù)調(diào)用時(shí), 主調(diào)函數(shù)把實(shí)參的值傳送給被調(diào)函數(shù)的形參從而實(shí)現(xiàn)主調(diào)函數(shù)向被調(diào)函數(shù)的數(shù)據(jù)傳送2021-11-11
C++實(shí)現(xiàn)批量提取PDF內(nèi)容
這篇文章主要為大家詳細(xì)介紹了如何使用C++批量提取PDF里文字內(nèi)容并導(dǎo)出到表格以及批量給?PDF?文件改名,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2025-02-02
C++實(shí)現(xiàn)有向圖鄰接表的構(gòu)建
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)有向圖鄰接表的構(gòu)建,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-04-04
C語(yǔ)言二叉排序樹(shù)的創(chuàng)建,插入和刪除
本文主要介紹了Java實(shí)現(xiàn)二叉排序樹(shù)的查找、插入、刪除、遍歷等內(nèi)容。具有很好的參考價(jià)值,下面跟著小編一起來(lái)看下吧2021-10-10

