Qt实现模糊匹配功能的实例详解

目录
  • 1.准备基础数据
  • 2.创建并实例化匹配类
  • 3.控件绑定

对于浏览器的使用,我想大家一定不会陌生吧,输入要搜索的内容时,会出现相应的匹配信息。

那么,今天我要讲述的也是这样一个功能。

首先看一下展示效果

输入任意文本后,弹出具有该文本的符合项,也就是模糊查询。

实现功能的核心是:QCompleter

该类可以在任何Qt小部件中提供自动完成搜索功能,例如:QLineEdit、QComboBox。当输入指定字符后,QCompleter会根据单词列表提供的内容进行筛查。

在这里,我是采用QLineEdit + QCompleter组合使用的。

下面我来介绍下如何使用的吧~

1.准备基础数据

想要让QCompleter完成模糊匹配功能,前提必须要有一个可供查询的库文件,否则是无法搜索的。

这里就简单插入一些字符串吧~

QStringList listData;
listData << QStringLiteral("基础数据1");
listData << QStringLiteral("基础数据n");

2.创建并实例化匹配类

QCompleter *m_pCompleter = new QCompleter(listData);

设置匹配方式,在Completer中存在以下几种匹配模式,分别列举,如下:

模式 描述
Qt::MatchExactly 只匹配第一个字/词
Qt::MatchFixedString 只匹配第一个词,并且区分大小写
Qt::MatchContains 只要字符串中包含字/词就能匹配
Qt::MatchStartsWith 与第一个字/词进行匹配
Qt::MatchEndsWith  
Qt::MatchCaseSensitive 搜索区分大小写
Qt::MatchRegExp 使用正则表达式作为搜索项执行基于字符串的匹配(Qt5.15)
Qt::MatchRegularExpression 使用正则表达式作为搜索项执行基于字符串的匹配(Qt5.15)
Qt::MatchWildcard 使用带有通配符的字符串作为搜索条件,执行基于字符串的匹配
Qt::MatchWrap 执行一个环绕的搜索,这样当搜索到达模型中的最后一项时,就会从第一个项开始,直到检查完所有项为止
Qt::MatchRecursive 搜索整个层次结构

在使用过程中,一般采用:Qt::MatchContains的定义比较多。

代码设置,如下:

m_pCompleter->setFilterMode(Qt::MatchContains);

3.控件绑定

ui.edit->setCompleter(m_pCompleter);

到此,一个简单的模糊搜索就实现了,其实在使用过程中为了美观起见,还可以对QCompleter中展示的文本进行美化~

例如:

滚动条风格

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风格

QString qsCompleterStyle =
//设置:背景色、字体颜色、大小、字体风格
"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;}";

风格设置,如下:

m_pCompleter->popup()->setStyleSheet(qsCompleterStyle + g_scrollVerticalWidth8Gray);

单纯的设置风格肯定是不行的,想要让风格有效,必须设置:QStyledItemDelegate

QStyledItemDelegate *d = new QStyledItemDelegate;
m_completerName->popup()->setItemDelegate(d);

最终展示效果,如下:

到此这篇关于Qt实现模糊匹配功能的实例详解的文章就介绍到这了,更多相关Qt模糊匹配功能内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 使用Qt QSS绘制简单美化界面功能

    目录 使用Qt绘制一个简约美观的界面-使用QSS简单美化 基本控件布局 界面的简单美化 QSS 添加图片 方法1:添加资源 方法2:直接指定图片在计算机中的绝对 / 相对路径 使用Qt绘制一个简约美观的界面-使用QSS简单美化 基本控件布局 以绘制登录界面为例,创建一个继承自Qwidget的设计师界面类 为了使得控件排放整齐有序,可以使用layout布局进行辅助 首先,添加控件,然后按照类似css的页面布局方式,在控件下方添加一Vertical Spacer垫片,用于控制该控件与其他控件的下边距

  • Qt实现小功能之复杂抽屉效果详解

    目录 功能讲解 自定义标题widget 标题名称控件的创建 QCheckBox控件的创建 自定义内容Widget 创建显示高度描述控件 QScrollArea中widget实现 QScrollArea子窗口的提升 在Qt自带的控件中,也存在抽屉控件:QToolBar.但是,该控件有个缺点:一次只能展开一个抽屉信息,无法实现多个展开.为此,实现了如下效果的程序: 下面对这种实现效果进行讲解~ 功能讲解 开发环境:VS2017 + Qt5.14.2 64位 实现的核心技术: 1:QScrollAre

  • Qt实现打地鼠游戏的方法详解

    目录 功能讲解 1.确定地鼠数量 2.定义游戏难易程序 3.难度切换 4.定时器处理 总结 今天与大家分享一个小游戏的实现:打地鼠 看一下实现效果吧~ 在指定的时间内打中一定数额的地鼠,否则失败,就如上述展示效果一样,自己写的小程序,居然连第二关也过不去,还挺尴尬的! 实现打地鼠小游戏不难,最主要的核心就是依靠定时器,按照一定间隔触发.接下来,我来讲解下是如何实现的吧! 功能讲解 开发环境:VS2017 + Qt5.14.2 x64 1.确定地鼠数量 对于打地鼠这款游戏来说,地鼠是从任意的洞口钻

  • Qt实现小功能之圆形进度条的方法详解

    目录 功能 图形绘制 1.绘制窗口整体背景色值 2.圆形进度条通道绘制 3.圆形进度条绘制 4.文本绘制 数值计算 1.计算步长 2.实时数据计算 在Qt自带的控件中,只有垂直进度条.水平进度条两种. 在平时做页面开发时,有些时候会用到圆形进度条,比如说:下载某个文件的下载进度. 展示效果,如下图所示: 实现这个功能主要由以下几个重点: 1:图形绘制 2:数值计算 也算是一个初级例子,下面我来讲解下如何实现这个简单的小功能吧! 功能 自定义绘制类:QRoundedProgress 继承自QWid

  • Qt实现模糊匹配功能的实例详解

    目录 1.准备基础数据 2.创建并实例化匹配类 3.控件绑定 对于浏览器的使用,我想大家一定不会陌生吧,输入要搜索的内容时,会出现相应的匹配信息. 那么,今天我要讲述的也是这样一个功能. 首先看一下展示效果 输入任意文本后,弹出具有该文本的符合项,也就是模糊查询. 实现功能的核心是:QCompleter 该类可以在任何Qt小部件中提供自动完成搜索功能,例如:QLineEdit.QComboBox.当输入指定字符后,QCompleter会根据单词列表提供的内容进行筛查. 在这里,我是采用QLine

  • django 使用全局搜索功能的实例详解

    安装需要的包 1 第一步: 全文检索不同于特定字段的模糊查询,使用全文检索的效率更高,并且能够对于中文进行分词处理. haystack:全文检索的框架,支持whoosh.solr.Xapian.Elasticsearc四种全文检索引擎 whoosh:纯Python编写的全文搜索引擎对于小型的站点,whoosh已经足够使用 jieba:一款免费的中文分词包 1)在虚拟环境中依次安装需要的包. pip install django-haystack pip install whoosh pip in

  • Django实现web端tailf日志文件功能及实例详解

    这是Django Channels系列文章的第二篇,以web端实现tailf的案例讲解Channels的具体使用以及跟Celery的结合 通过上一篇 <Django使用Channels实现WebSocket--上篇> 的学习应该对Channels的各种概念有了清晰的认知,可以顺利的将Channels框架集成到自己的Django项目中实现WebSocket了,本篇文章将以一个Channels+Celery实现web端tailf功能的例子更加深入的介绍Channels 先说下我们要实现的目标:所有

  • swift where与匹配模式的实例详解

    swift where与匹配模式的实例详解 前言: 在众多 Swift 提供给 Objective-C 程序员使用的新特性中,有个特性把自己伪装成一个无聊的老头,但是却在如何优雅的解决"鞭尸金字塔"的问题上有着巨大的潜力.很显然我所说的这个特性就是 switch 语句, 对于很多 Objective-C 程序员来说,除了用在 Duff's Device 上比较有趣之外,switch 语句非常笨拙,与多个 if 语句相比,它几乎没有任何优势. 1.基本使用 Swift中switch语句c

  • ThinkPHP3.2.3框架邮件发送功能图文实例详解

    本文实例讲述了ThinkPHP3.2.3框架邮件发送功能.分享给大家供大家参考,具体如下: 背景 web 开发过程中,经常会用到邮件的发送功能,比如接收消费账单的提醒.亚马逊图书推荐的推送,或者网站不正常操作报警的邮件提示等. 下面是一个在ThinkPHP 3.2.3 框架下集成 PHPMailer 使用的邮件发送功能实现过程,仅供参考,谢谢... 一.前期准备 1).首先对 STMP 的知识稍作了解 STMP 简介 <百度百科> 2).开启邮箱 STMP 服务 以 163.com 邮箱为例,

  • AngularJS标签页tab选项卡切换功能经典实例详解

    本文实例讲述了AngularJS实现标签页tab选项卡功能.分享给大家供大家参考,具体如下: 选项卡一: JavaScript+html+css <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>www.jb51.net js标签页tab切换</title> <style> #div1 .active{ background:blue

  • PHP简单验证码功能机制实例详解

    本文实例讲述了PHP简单验证码功能机制.分享给大家供大家参考,具体如下: 网站的安全性是开发者不可忽视的一个问题,目前使用最多的一种可以提高网站安全性的方法就是使用验证码功能机制,有的仅仅使用一个几位数字字母混乱的验证码,有的进行手机发送短信进行验证,有的使用邮箱发送邮件进行验证,但是这个验证码功能机制是如何实现的呢?下面就为大家详细解释验证码功能机制的实现思路以及简单的实现方法. 1.验证码功能机制实现思路 ① 常规的验证码实现: a.产生一张png的图片 b.为图片设置背景色 c.设置字体颜

  • 微信JSSDK分享功能图文实例详解

    本文实例讲述了微信JSSDK分享功能.分享给大家供大家参考,具体如下: 这里以微信分享到朋友圈,分享给微信好友为例为参考,进行调用测试,想添加其他的功能,自行查看开发人员文档即可 工欲善其事,必先利其器,好好利用下边的帮助工具,都是腾讯给开发人员的工具 1.微信开发者说明文档:点击查看 2.微信WEB开发者工具: Windows 64位版本:下载地址 Windows 32位版本:下载地址 Mac版本:下载地址 3.微信JSSDK分享sample:点击下载 4.在线DEMO:http://203.

  • javascript实现Java中的Map对象功能的实例详解

    javascript  自定义对象实现Java中的Map对象功能 Java中有集合,Map等对象存储工具类,这些对象使用简易,但是在JavaScript中,你只能使用Array对象. 这里我创建一个自定义对象,这个对象内包含一个数组来存储数据,数据对象是一个Key,可以实际存储的内容! 这里Key,你要使用String类型,和Java一样,你可以进行一些增加,删除,修改,获得的操作. 使用很简单,我先把工具类给大家看下: /** * @version 1.0 * @author cuisuqia

  • 正则表达式实现字符的模糊匹配功能示例

    本文实例讲述了正则表达式实现字符的模糊匹配功能.分享给大家供大家参考,具体如下: package com.cn.util; import java.util.regex.Pattern; /** * 正则表达式 工具类 * * @author lifangyu */ public class RegexUtil { /* * IP地址的匹配标达式 ( // \\d{1,3}) // :\d // 0~9数字,{1,3} // 至少一位,最多三位) */ private static String

随机推荐