QT 字符串操作常用接口函数

news2025/1/17 0:20:33

目录

    • 常见字符串处理函数
    • 空白字符串处理函数
    • 查询字符串数据
    • 字符串比较
    • 字符串的转换
    • QT版本的STL
    • QLinkedList和QVector的区别
    • QT提供的STL命名风格的迭代器
    • QMap和QHash

经过该简单设置可以防止msvc环境下使用qdebug打印输出时出现中文乱码的问题。

#include "learn.h"
#include <QtWidgets/QApplication>
#include <QString>
#include <QtDebug>
#include <QTextCodec>
// 解决qdebug 输出中文乱码的情况
#pragma execution_character_set("utf-8")  

常见字符串处理函数

接口定义接口功能
QString &QString::sprintf(const char *cformat, …)支持的格式定义符和C++中的sprintf功能类似,返回值是一个QString对象
QString QString::arg(const QString &a, int fieldWidth = 0, QChar fillChar = QLatin1Char(’ ')) const字符串组合方式输出一个QString对象,提供一个支持多种数据类型重载的arg函数
QString::insert指定位置插入字符串
QString::prepend头插一个字符串
QString::replace(const QString &before, const QString &after)使用after 替换掉before
//格式输出一个字符串
qDebug() << QString().sprintf("%s", "1111111");
# out"1111111"

qDebug() << QString("%1来自%2今年%3岁了").arg("张三")
                            .arg("新疆").arg("21");
# out"张三来自新疆今年21岁了"

//指定位置插入字符串
QString tmp = "11";
tmp.insert(0,"10_");
qDebug() << tmp;
# out"10_11"

//头插字符串
tmp.prepend("日期:");
qDebug() << tmp;
# out"日期:10_11"

//字符串替换
tmp.replace(QString("1"), QString("2"));
qDebug() << tmp;
# out"日期:20_22"

空白字符串处理函数

接口定义接口功能
QByteArray QByteArray::trimmed() const删除字符串的两端的空白字符
QByteArray QByteArray::simplified() const删除字符串的两端的空白字符,使用单个空格替换字符串中出现的空白字符
//移除字符串的两边空格
QString str = " welcome \t to \n you";
qDebug() << str.trimmed();
# out"welcome \t to \n you"

//移除字符串的全部空格
qDebug() << str.simplified();
#out"welcome to you"

查询字符串数据

函数定义函数功能
bool QByteArray::startsWith(const QByteArray &ba) const如果此字节数组以字节数组ba开头,则返回true;否则返回false, CaseInsensitive为可选择参数,可以设置此参数从而区分大小写,否则默认是不区分大小写的。
bool QByteArray::endsWith(const QByteArray &ba) const从结尾开始查找
bool QByteArray::contains(const QByteArray &ba) const判断一个指定的字符串是否出现过
//查找第一次出现的字符串
QString str = "Welcome to you";
//CaseInsensitive: 不区分大小写
qDebug() << str.startsWith("Welcome", Qt::CaseInsensitive);
qDebug() << str.startsWith("to", Qt::CaseInsensitive);

#out:
	true
	false

//查找最后一次出现的字符串
str = "Welcome to you";
//区分大小写
qDebug() << str.endsWith("you");
qDebug() << str.endsWith("You");
#out
	true
	false

QString str = "Welcome to you";
//不区分大小写
qDebug() << str.contains("to");
qDebug() << str.contains("Welcome");
qDebug() << str.contains("you");
# out
	true
	true
	true

字符串比较

函数定义功能说明
int QString::localeAwareCompare(const QString &s1, const QString &s2)比较s1与s2,如果s1小于、等于或大于s2,则返回一个小于、等于或大于零的整数。
int QByteArray::compare(QString&,QString&, Qt::CaseSensitivity cs = Qt::CaseSensitive) const可以设置是否区分大小写进行字符串的比较
//比较两个字符串的大小,小于返回负数,相等返回0,大于返回正数
QString str1 = "Welcome to you";
QString str2 = "Welcome to you";
qDebug() <<  QString::localeAwareCompare(str1, str2);

// compare 函数可以指定是否区分大小写来进行比较
str1 = "Welcome to You";
str2 = "Welcome to you";
qDebug() << QString::compare(str1, str2, Qt::CaseInsensitive);

字符串的转换

QString提供的字符编码集的转换函数将会返回一个const char* 类型版本的QByteArray,即构造函数QByteArray(const char*)构造的QByteArray对象。

QByteArray类具有一个字节数组,它既可以存储原始字节(原始字节),也可以存储传统的以“\0”结尾的8位的 字符串。在Qt中,使用QByteArray比使用const char * 存储传统的以“\0”结尾的8位的字符串.在Qt中,使用QByteArray比使用Const char*更方便,QByteArray也支 持隐式共享。转换函数有以下几种。

函数定义函数功能
toAscill返回一个Ascill 编码的8位字符串, 返回值都是QByteArray
toLatin1返回一个toLatin-1编码的8位字符串, 返回值都是QByteArray
toUtf8返回一个Utf8编码的8位字符串, 返回值都是QByteArray
toLocal8Bit返回一个系统本地编码的8位字符串, 返回值都是QByteArray
QString str = "Welcome to you";
auto utf = str.toUtf8();
auto Latin1 = str.toLatin1();
auto Local8Bit = str.toLocal8Bit();

qDebug() << utf;
qDebug() << Latin1;
qDebug() << Local8Bit;

#out
	"Welcome to you"
	"Welcome to you"
	"Welcome to you"

QT版本的STL

  • QList是迄今为止最常用的容器类,它存储给定数据类型T的一列数值。

  • QList维护了一个指针数组,该数组存储的指针指向QList存储的列表维护了一个指针数组,该数组存储的指针指向QList存储的列表项的内容。

对于不同的数据类型,QList采取不同的存储策略,存储策略有以下几种.

  • 如果T是一个指针类型或指针大小的基本类型(即该基本类型占有的字节数和指针类型占有的字节数相同),QList 会将数值直接存储在它的数组中。

  • 如果QList存储对象的指针,则该指针指向实际存储的对象。

//直接存储对象
QList<QString> list1;
list1 << QString("%1来自%2今年%3岁了").arg("张三").
                            arg("新疆").arg("21");
qDebug() << sizeof(list1);
# out
	8
	
//存储对象的指针
auto s = QString("%1来自%2今年%3岁了").arg("张三").arg("新疆").arg("21");
QList<QString*> list2;
list2 << &s;

qDebug() << sizeof(list2);
# out
	8

通过结果可以得知qlist最终不管T是什么类型,但是最终存储的一定是指针类型,即使直接存储一个对象和存储一个对象的指针二者的qlist对象大小都是一样的

QLinkedList和QVector的区别

QLinkedList类

QLinkedList是一个链式列表,它以非连续的内存块保存数据。
QLinkedList不能使用下标,只能使用迭代器访问它的数据项。

QVector类

QVector在相邻的内存中存储给定数据类型T的一组数值。
QVector既可以使用下标访问数据项,也可以使用迭代器访问数据项。

QT提供的STL命名风格的迭代器

在这里插入图片描述

QMap和QHash

在这里插入图片描述
QMap和QHash的简单使用

 QMap<QString, QString> map;
 map.insert("小8", "11");
 map.insert("小9", "12");
 map.insert("小7", "13");

 //构造一个Qmap的迭代器
 QMap<QString, QString>::iterator it = map.begin();
 while (it != map.end()) 
 {
     qDebug() << "key:" << it.key() << "val:" << it.value();
     it++;
 }

 //讲小王的年龄修改
 for (auto it = map.begin(); it != map.end(); it++) 
     if (it.key() == "小王")
         it.value() = "20";

 qDebug() << "--------------------------------------";
 it = map.begin();
 while (it != map.end())
 {
     qDebug() << "key:" << it.key() << "val:" << it.value();
     it++;
 }

输出:

key: "小7" val: "13"
key: "小8" val: "11"
key: "小9" val: "12"
--------------------------------------
key: "小7" val: "13"
key: "小8" val: "11"
key: "小9" val: "12"

QHash 并不根据key的值大小进行排序,而是随机的无序的

  QHash<QString, QString> has;
  has.insert("小8", "11");
  has.insert("小9", "12");
  has.insert("小7", "13");

  //构造一个Qmap的迭代器
  QHash<QString, QString>::iterator it = has.begin();
  while (it != has.end())
  {
      qDebug() << "key:" << it.key() << "val:" << it.value();
      it++;
  }

  //讲小王的年龄修改
  for (auto it = has.begin(); it != has.end(); it++)
      if (it.key() == "小王")
          it.value() = "20";

  qDebug() << "--------------------------------------";
  it = has.begin();
  while (it != has.end())
  {
      qDebug() << "key:" << it.key() << "val:" << it.value();
      it++;
  }

输出

key: "小9" val: "12"
key: "小7" val: "13"
key: "小8" val: "11"
--------------------------------------
key: "小9" val: "12"
key: "小7" val: "13"
key: "小8" val: "11"

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/27116.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

长话短说:学习网络安全自学好还是报培训班?

无论你是大学生还是在职人员&#xff0c;想学网络安全时&#xff0c;都会面临两个选择&#xff0c;自学或者报班。报班通常太费钱&#xff0c;时间又不自由&#xff1b;自学又不知道如何下手&#xff0c;担心自己坚持不下来。怎么办&#xff1f; 我们先分析一下自学和培训班的…

【文本分类】《融合注意力和剪裁机制的通用文本分类模型》

阅读摘要&#xff1a;   针对实际场景中长短文本大量的情况&#xff0c;提出了双通道注意力机制与长文本裁剪机制来改进文本分类模型&#xff0c;最终提高了精度。 参考文献&#xff1a;   [1] 融合注意力和剪裁机制的通用文本分类模型 参考论文信息 论文名称&#xff1a;《…

第三版全球干旱指数和潜在蒸散数据发布

Robert J. Zomer &#xff1b;JianchuXu&#xff1b;AntonioTrabucco(Kunming Institute of Botany, Chinese Academy of Science&#xff1b;Euro-Mediterranean Center on Climate Change, IAFES Division, Sassari, Italy) 摘要 潜在蒸散(Potential evapotranspiration&…

Linux Shell 自动交互功能实现

1. EOF 多文本输入 需求案例 1 新交付了一批机器&#xff0c;每台机器只分配了一块落盘 &#xff0c;现在根据需求对该盘进行分区并实现挂载&#xff0c;如何实现&#xff1f; 需求分析&#xff1a; 对于一个盘&#xff0c;实现分区挂载到不同目录&#xff0c;通常思路有两…

灯具行业MES解决方案,实现产品的正反向追溯

灯具照明行业产业链主要包括上游原材料、中游照明产品生产及封装、下游照明细分应用领域。产业链上游、中游多为资本密集与技术密集型行业&#xff0c;产品高度标准化&#xff0c;市场相对集中。而产业链下游产品需求相对个性化&#xff0c;多品类、多SKU&#xff0c;市场集中度…

探索性数据分析

有目的性的探索数据集以获取具体的优化方向和思路。 Intuition 探索性数据分析 (EDA) 以了解数据集的信号和细微差别。这是一个循环过程&#xff0c;可以在开发过程的各个阶段&#xff08;标记之前/之后、预处理等&#xff09;完成&#xff0c;具体取决于问题的定义程度。例如&…

【Proteus仿真】【STM32单片机】蔬菜大棚温湿度控制系统设计

文章目录一、主要功能二、硬件资源三、软件设计四、实验现象联系作者一、主要功能 本项目使用Proteus8仿真STM32单片机控制器&#xff0c;使用LCD1602液晶、DHT11温湿度、蜂鸣器、按键、LED、继电器、电机模块等。 主要功能&#xff1a; 系统运行后&#xff0c;LCD1602显示DH…

setup获取props和自定义事件、通过expose暴露给ref获取属性和方法、setup顶层async、setup返回函数

文章目录1. setup获取props和自定义事件2. 通过expose暴露给ref获取属性和方法3. setup顶层async4. setup返回函数1. setup获取props和自定义事件 child 组件&#xff1a; <template><div><h3>我是child组件 -- {{ title }}</h3><button click&qu…

We have awesome remote U.S. jobs waiting for engineers like you.

发件人&#xff1a;Turing - U.S. Software Jobs <hiringturing.com> Hi I saw your profile online and wanted to reach out! You might be a great fit for many high-paying remote U.S. software engineering opportunities on Turing.com. Turing is based in …

steam搬砖,长期稳定副业,附防坑指南助你不掉坑

大家伙&#xff0c;我是阿阳 今天给大家拆解一个冷门项目&#xff0c;国外steam游戏搬砖项目&#xff0c;这个项目也是自己正在做的第二个项目&#xff0c;虽然冷门&#xff0c;不暴利&#xff0c;做了这么久赚钱一直很稳定。站在一个搞钱人的角度来说&#xff0c;这个项目作为…

Docker部署单节点Kafka

文章目录Docker部署单节点Kafka参考镜像wurstmeister/zookeeper Overviewwurstmeister/kafka Overview部署单Brokerkafka 环境变量&#xff1a;启动与停止命令测试验证&#xff1a;参考文章Docker部署单节点Kafka 参考镜像 wurstmeister/zookeeper Overview docker pull wur…

Hadoop总结——HDFS

一、HDFS概述 1.1 HDFS产生背景 随着数据量越来越大&#xff0c;在一个操作系统管辖的范围内存不下了&#xff0c;那么就分配到更多的操作系统管理的磁盘中&#xff0c;但是不方便管理和维护&#xff0c;迫切需要一种系统来管理多台机器上的文件&#xff0c;这就是分布式文件…

记一次自定义starter引发的线上事故复盘

前言 本文素材来源于业务部门技术负责人某次线上事故复盘分享。故事的背景是这样&#xff0c;该业务部门招了一个技术挺不错的小伙子小张&#xff0c;由于小张技术能力在该部门比较突出&#xff0c;在入职不久后&#xff0c;他便成为这个部门某个项目组的team leader&#xff…

计算机外设:显示器是如何工作的?

本节我们将了解计算机的外设之一&#xff1a;显示器的底层工作原理。通过本节&#xff0c;你会知道电脑显示器是如何实时展示我们在计算机上的操作的&#xff0c;比如显示出一张“E”的字符。最后总结了计算机编程的本质&#xff0c;就是人们是通过设计&#xff0c;让字节代表不…

超迷你机械臂机器人,YYDS

真正的大师,永远都怀着一颗学徒的心&#xff01; 一、项目简介 超迷你机械臂机器人&#xff0c;YYDS 核心板&#xff1a; REF核心板 REF底板&#xff08;机械臂底座里面的控制器电路板&#xff09; 步进电机驱动 Peak示教器 文件&#xff1a; 3D模型设计源文件。 20步进…

Python机器学习 | AI芯片调研

AI芯片调研 1、 概念 AI芯片又叫AI加速器,专门用于处理人工智能应用中的大量计算任务的模块。 注意:其他非计算任务仍由CPU处理 2、 背景 神经网络需要大量的矩阵运算,CPU和传统计算架构无法满足对于并行计算能力的需求,需要特殊定制的AI芯片(GPU、TPU、NPU、DPU等等)…

Go Web项目学习之项目结构

风离不摆烂学习日志 Day4 — Go Web项目学习之项目结构 创建项目配置代理 下载加速 go 包代理 GOPROXYhttps://goproxy.cn,direct 本项目学习自&#xff1a; [github.com](https://github.com/gnimli/go-web-mini) 项目结构分层 ├─common # casbin mysql zap validator 等公…

web概述18

JSP JSP是Sun为了解决动态生成HTML文档的技术&#xff0c;通过Servlet输出简单html页面信息都非常不方便。如果要输出一个复杂页面的时候&#xff0c;就更加的困难&#xff0c;而且不利于页面的维护和调试。所以sun公司推出一种叫做jsp的动态页面技术来实现对页面的输出繁锁工…

【设计模式】 - 结构型模式 - 适配器模式

目录标题1. 前言适配器模式1. 概述2. 结构3. 实现3.1 类适配器模式&#xff08; 继承&#xff09;--耦合度高代码实现3.2 对象适配器模式&#xff08;聚合&#xff09;代码实现类适配器与对象适配器的区别4. 适配器模式的优缺点1. 前言 结构型模式描述如何将类或对象按某种布局…

Borland Delphi 2005对Delphi语言的支持

Borland Delphi 2005对Delphi语言的支持 Borland Delphi是Borland Delphi的最新版本&#xff0c;它为用户的Microsoft Windows操作系统和1.1本身的Microsoft.NET Framework版本提供了快速应用程序开发。Delphi Borland 2005被认为具有主要的三个不同的字符&#xff0c;如Win32…