Qt實(shí)現(xiàn)模糊匹配功能的實(shí)例詳解
對于瀏覽器的使用,我想大家一定不會陌生吧,輸入要搜索的內(nèi)容時(shí),會出現(xiàn)相應(yīng)的匹配信息。
那么,今天我要講述的也是這樣一個(gè)功能。
首先看一下展示效果
輸入任意文本后,彈出具有該文本的符合項(xiàng),也就是模糊查詢。
實(shí)現(xiàn)功能的核心是:QCompleter
該類可以在任何Qt小部件中提供自動(dòng)完成搜索功能,例如:QLineEdit、QComboBox。當(dāng)輸入指定字符后,QCompleter會根據(jù)單詞列表提供的內(nèi)容進(jìn)行篩查。
在這里,我是采用QLineEdit + QCompleter組合使用的。
下面我來介紹下如何使用的吧~
1.準(zhǔn)備基礎(chǔ)數(shù)據(jù)
想要讓QCompleter完成模糊匹配功能,前提必須要有一個(gè)可供查詢的庫文件,否則是無法搜索的。
這里就簡單插入一些字符串吧~
QStringList listData; listData << QStringLiteral("基礎(chǔ)數(shù)據(jù)1"); listData << QStringLiteral("基礎(chǔ)數(shù)據(jù)n");
2.創(chuàng)建并實(shí)例化匹配類
QCompleter *m_pCompleter = new QCompleter(listData);
設(shè)置匹配方式,在Completer中存在以下幾種匹配模式,分別列舉,如下:
模式 | 描述 |
---|---|
Qt::MatchExactly | 只匹配第一個(gè)字/詞 |
Qt::MatchFixedString | 只匹配第一個(gè)詞,并且區(qū)分大小寫 |
Qt::MatchContains | 只要字符串中包含字/詞就能匹配 |
Qt::MatchStartsWith | 與第一個(gè)字/詞進(jìn)行匹配 |
Qt::MatchEndsWith | |
Qt::MatchCaseSensitive | 搜索區(qū)分大小寫 |
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í),就會從第一個(gè)項(xiàng)開始,直到檢查完所有項(xiàng)為止 |
Qt::MatchRecursive | 搜索整個(gè)層次結(jié)構(gòu) |
在使用過程中,一般采用:Qt::MatchContains
的定義比較多。
代碼設(shè)置,如下:
m_pCompleter->setFilterMode(Qt::MatchContains);
3.控件綁定
ui.edit->setCompleter(m_pCompleter);
到此,一個(gè)簡單的模糊搜索就實(shí)現(xiàn)了,其實(shí)在使用過程中為了美觀起見,還可以對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)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C語言數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)字符串分割的實(shí)例
這篇文章主要介紹了C語言數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)字符串分割的實(shí)例的相關(guān)資料,希望通過本文能幫助到大家實(shí)現(xiàn)這樣的功能,需要的朋友可以參考下2017-10-10C++實(shí)現(xiàn)LeetCode(105.由先序和中序遍歷建立二叉樹)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(105.由先序和中序遍歷建立二叉樹),本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07C語言實(shí)現(xiàn)圖書管理系統(tǒng)開發(fā)
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)圖書管理系統(tǒng)開發(fā),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-08-08利用ace的ACE_Task等類實(shí)現(xiàn)線程池的方法詳解
本篇文章是對利用ace的ACE_Task等類實(shí)現(xiàn)線程池的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05C語言 實(shí)現(xiàn)輸入任意多個(gè)整數(shù)
這篇文章主要介紹了C語言 實(shí)現(xiàn)輸入任意多個(gè)整數(shù),具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12C++學(xué)習(xí)之算術(shù)運(yùn)算符使用詳解
運(yùn)算符是計(jì)算機(jī)語言提供的能對數(shù)據(jù)進(jìn)行基本運(yùn)算操作的功能體。而算術(shù)運(yùn)算符用來對數(shù)字型數(shù)據(jù)進(jìn)行數(shù)學(xué)語義上的加、減、乘、除。本文通過講解清楚算術(shù)運(yùn)算符,讓大家了解使用C++運(yùn)算符時(shí)應(yīng)該注意的事項(xiàng)2022-06-06詳解C語言中freopen()函數(shù)和fclose()函數(shù)的用法
這篇文章主要介紹了詳解C語言中freopen()函數(shù)和fclose()函數(shù)的用法,是C語言入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下2015-08-08