C++正则表达式基础
文章目录
- 1. 查找第一个匹配的
- 2. 查找所有结果
- 3. 打印匹配结果的上下文
- 4. 使用子表达式
- 5. 查找并替换
注意:
.
(点)在括号中没有特殊含义,无需转义用\
转义。
1. 查找第一个匹配的
#include <iostream>
#include <regex>using namespace std;int main(void)
{string pattern = "[^c]ei";pattern = "[[:alpha:]]*" + pattern + "[[:alpha:]]*";regex policy(pattern); string text = "receipt freind theif receive";smatch results;if(regex_search(text, results, policy))cout << results.str() << endl;
}
输出结果:
freind
2. 查找所有结果
#include <iostream>
#include <regex>using namespace std;int main (void)
{string pattern = "[^c]ei";pattern = "[[:alpha:]]*" + pattern + "[[:alpha:]]*";// 忽略大小写regex policy (pattern, regex::icase);string text = "receipt freind theif receive";for (sregex_iterator it (text.begin(), text.end(), policy), end_it;it != end_it; ++it)cout << it->str() << endl;
}
其中,比较难理解的是sregex_iterator it (text.begin(), text.end(), policy), end_it
,这行代码是定义了it
迭代器来进行遍历查询,end_it
为空sregex_iterator
,起到尾后迭代器的作用。
输出结果:
freind
theif
3. 打印匹配结果的上下文
#include <iostream>
#include <regex>using namespace std;string text ="Once there were two mice. They were friends. One mouse ""lived in the country; the other mouse lived in the city.""After many years the Country mouse saw the City mouse;""he said, \"Do come and see me at my house in the country.""\" So the City mouse went. The City mouse said, \"This food""is not good, and your house is not good. Why do you live ""in a hole in the field? You should come and live in the ""city. You would live in a nice house made of stone. You ""would have nice food to eat. You must come and see me at""my house in the city.\"The Country mouse went to the house""of the City mouse. It was a very good house. Nice food ""was set ready for them to eat. But just as they began to""eat they heard a great noise. The City mouse cried, \" Run""! Run! The cat is coming!\" They ran away quickly and hid"".After some time they came out. When they came out, the ""Country mouse said, \"I do not like living in the city.""I like living in my hole in the field. For it is nicer""to be poor and happy, than to be rich and afraid.";int main (void)
{string pattern = "you";pattern = "[[:alpha:]]*" + pattern + "[[:alpha:]]*";regex policy (pattern, regex::icase);for (sregex_iterator it (text.begin(), text.end(), policy), end_it;it != end_it ; ++it) {auto pos = it->prefix().length();pos = pos > 40 ? pos - 40 : 0;cout << it->prefix().str().substr (pos)<< "\n\t\t>>> "<< it->str()<< " <<<\n"<< it->suffix().str().substr (0, 40)<< endl;}}
输出结果:
mouse said, "This foodis not good, and >>> your <<<house is not good. Why do you live in ahouse is not good. Why do >>> you <<<live in a hole in the field? You shouldlive in a hole in the field? >>> You <<<should come and live in the city. You wshould come and live in the city. >>> You <<<would live in a nice house made of ston
uld live in a nice house made of stone. >>> You <<<would have nice food to eat. You must cwould have nice food to eat. >>> You <<<must come and see me atmy house in the
4. 使用子表达式
#include <iostream>
#include <regex>using namespace std;string text ="Once there were two mice. They were friends. One mouse ""lived in the country; the other mouse lived in the city.""After many years the Country mouse saw the City mouse;""he said, \"Do come and see me at my house in the country.""\" So the City mouse went. The City mouse said, \"This food""is not good, and your house is not good. Why do you live ""in a hole in the field? You should come and live in the ""city. You would live in a nice house made of stone. You ""would have nice food to eat. You must come and see me at""my house in the city.\"The Country mouse went to the house""of the City mouse. It was a very good house. Nice food ""was set ready for them to eat. But just as they began to""eat they heard a great noise. The City mouse cried, \" Run""! Run! The cat is coming!\" They ran away quickly and hid"".After some time they came out. When they came out, the ""Country mouse said, \"I do not like living in the city.""I like living in my hole in the field. For it is nicer""to be poor and happy, than to be rich and afraid.";int main (void)
{string pattern = "! The (.*?)(coming)[[:alnum:]]*";regex policy (pattern);for (sregex_iterator it (text.begin(), text.end(), policy), end_it; it != end_it ; ++it) {cout << "总表达式\n\t" << it->str() << "\n";if ( (*it) [1].matched)cout << "第1个子表达式\n\t" << it->str (1) << "\n";if ( (*it) [2].matched)cout << "第2个子表达式\n\t" << it->str (2);}}
输出结果:
总表达式! The cat is coming
第1个子表达式cat is
第2个子表达式coming
5. 查找并替换
regex_replace()
用于查找并替换,
#include <iostream>
#include <regex>
#include <sstream>using namespace std;static const string text ="morgan (201) 555-2368 862-555-0123\n""drew (973)555.0130\n""lee (609) 555-0132 2015550175 800.555-0000";
int main (void)
{string phone_pattern ="(\\()?" //可选左括号"(\\d{3})" //区号"(\\))?" //可选右括号"([-. ])?" //可选分隔符"(\\d{3})" //前三位"([-. ])?" //可选分隔符"(\\d{4})"; //后四位regex policy (phone_pattern);string format = "$2.$5.$7";//格式为 xxx.xxx.xxxxistringstream input (text);string line;while (getline (input, line)) {cout << regex_replace (line, policy, format) << endl;}
}
运行结果:
morgan 201.555.2368 862.555.0123
drew 973.555.0130
lee 609.555.0132 201.555.0175 800.555.0000
其中format
中的$n
表示第n个子表达式。
默认情况下,regex_replace
会输出整个输入序列。
未与正则表达式匹配的部分会原样输出,匹配的部分按照格式字符来输出。
如果只想要匹配的部分,我们可以通过添加format_no_copy
标志:
string fmt = "$2.$5.$7 "
cout << regex_replace (line, policy, format, regex_constants::format_no_copy) << endl;
此时输出结果:
201.555.2368 862.555.0123
973.555.0130
609.555.0132 201.555.0175 800.555.0000
标准库定义了用来在替换过程中控制匹配或格式的标志。这些标志可以传递给函数
regex_search
或regex_match
或是类smatch
的format
成员,例如format_no_copy
是类型match_flag_type
的值,定义在命名空间std::regex_constants
中。
匹配标志(定义在regex_constants::mat_flag_type
中)
match_default | 等价于format_default |
match_not_bol | 不将首字符作为行首处理 |
match_not_eol | 不将尾字符作为行尾处理 |
match_not_bow | 不将首字符作为单词首处理 |
match_not_eow | 不将尾字符作为单词尾处理 |
match_any | 如果存在多于一个匹配,则可返回任意一个匹配 |
match_not_null | 不匹配任何空序列 |
match_continuous | 匹配必须从输入的首字符开始 |
match_prev_avail | 输入序列包含第一个匹配之前的内容 |
format_default | 用ECMAScript规则替换字符串 |
format_sed | 用POSIX sed规则替换字符串 |
format_no_copy | 不输出输入序列中未匹配的部分 |
format_first_only | 只替换子表达式的第一次出现 |
参考书籍: C++ Primer 5 中文版
相关文章:
C++正则表达式基础
文章目录1. 查找第一个匹配的2. 查找所有结果3. 打印匹配结果的上下文4. 使用子表达式5. 查找并替换注意: .(点)在括号中没有特殊含义,无需转义用\转义。 1. 查找第一个匹配的 #include <iostream> #include <regex>using names…...
如何在网络安全中使用人工智能并避免受困于此
人工智能在网络安全中的应用正在迅速增长,并对威胁检测、事件响应、欺诈检测和漏洞管理产生了重大影响。根据Juniper Research的一份报告,预计到2023年,使用人工智能进行欺诈检测和预防将为企业每年节省110亿美元。但是,如何将人工…...
生态 | 人大金仓与超聚变的多个产品完成兼容认证
近日,人大金仓与超聚变数字技术有限公司(简称“超聚变”)完成了多款产品的兼容互认测试。测试表明,人大金仓KingbaseES V8数据库与超聚变服务器操作系统FusionOS、超聚变FusionOne基础设施完全兼容,人大金仓异构数据同…...
4自由度串联机械臂按颜色分拣物品功能的实现
1. 功能说明 本实验要实现的功能是:将黑、白两种颜色的工件分别放置在传感器上时,机械臂会根据检测到的颜色,将工件搬运至写有相应颜色字样区域。 2. 使用样机 本实验使用的样机为4自由度串联机械臂。 3. 运动功能实现 3.1 电子硬件 在这个…...
玩转结构体---【C语言】
⛩️博主主页:威化小餅干📝系列专栏:【C语言】藏宝图🎏 ✨绳锯⽊断,⽔滴⽯穿!一个编程爱好者的学习记录!✨目录结构体类型的声明结构体成员访问结构体传参前言我们是否有想过,为什么会有结构体呢…...
c语言指针怎么理解 第二部分
第四,指针有啥用。 比方说,我们有个函数,如下: int add(int x){ return (x1); //把输入的值加1并返回结果。 } 好了,应用的时候是这样的: { int a1; aadd(a); //add函数返回的是a1 //现在 a等于…...
GC简介和监控调优
GC简介: GC(Garbage Collection)是java中的垃圾回收机制,是Java与C/C的主要区别之一,在使用JAVA的时候,一般不需要专门编写内存回收和垃圾清理代 码。这是因为在Java虚拟机中,存在自动内存管理和垃圾清扫机制。 什么…...
Understanding The Linux Kernel --- Part2 Memory Addressing
内存寻址 操作系统自身不必完全了解物理内存,如今的微处理器包含的硬件线路使内存管理既高效又健壮,所以编程错误就不会对该程序之外的内存产生非法访问 x86如何进行芯片级内存寻址Linux如何利用寻址硬件 x86 三种不同的地址术语 逻辑地址 逻辑地址…...
前后端分页查询好大的一个坑(已解决)
前言:如果你在做前后端的分页查询,找不到错误,请你来看看是否是和我一样的情况?情况:做了一个前后盾UI的项目,有一个页面是查询系统日志,要进行分页查询;第一页的:第5页的…...
Python批量执行读取ini文件和写入ini文件时,性能比较低怎么办,给出解决方案和源码
Python批量执行读取ini文件和写入ini文件时,性能比较低怎么办,给出解决方案和源码 解决方案: 使用ConfigParser的缓存机制,可以避免频繁读取ini文件造成的性能问题。 将ini文件转换为json格式,使用json库进行读写操作…...
微机原理与接口技术 汇编语言程序设计DOS常用命令
OS(磁盘操作系统)命令,是DOS操作系统的命令,是一种面向磁盘的操作命令,主要包括目录操作类命令、磁盘操作类命令、文件操作类命令和其它命令。 使用技巧 DOS命令不区分大小写,比如C盘的Program Files&…...
4.ffmpeg命令转码规则、过滤器介绍、手动流map选项
在上章我们学习了ffmpeg命令行帮助以及选项查找 本章我们来深入学习ffmpeg命令转码规则、过滤器介绍、手动流map选项 参考链接: 1.ffmpeg命令行转码流程 ffmpeg命令行转码流程如下图所示: 对应中文则是: 步骤如下所示: ffmpeg调用libavformat库(包含解复用器)来读取输入文件…...
【python】标准库详解
注:最后有面试挑战,看看自己掌握了吗 文章目录Standard Library简介python内置对象如何安装发布第三方模块10最好用的模块汇总包的本质datetime模块案例Math模块random模块OS模块sys模块time模块总结自定义模块标准库模块用help查看time模块常用第三方库…...
Golang Map原理(底层结构、查找/新增/删除、扩缩容)
参考: 解剖Go语言map底层实现Go语言核心手册-3.字典 一、Go Map底层结构: Go map的底层实现是一个哈希表(数组 链表),使用拉链法消除哈希冲突,因此实现map的过程实际上就是实现哈希表的过程。 先来看下…...
Java_数组
数组 1.概念 需求:现在需要统计软件技术1班47名同学的成绩情况,例如计算平均成绩、最高成绩等。如果只能使用变量的话,那么需要定义100个变量,这样就比较复杂了。这时我们就可以使用数组来记住这47名同学的成绩,然…...
list与vector的区别
相信大家已经学过list与vector,关于它们的不同,我做了一些总结,如下表: vector list底层结构动态顺序表,一段连续的空间带头结点的双向链表随机访问支持随机访问,访问某个元素的效率…...
【C++、数据结构】位图、布隆过滤器、哈希切割(哈希思想的应用)
文章目录📖 前言1. 位图1.1 海量数据处理思路分析:1.2 位图的具体实现:1.3 用位图解决问题:应用一:应用二:应用三:2. 布隆过滤器2.1 布隆过滤器的概念:2.2 布隆过滤器的测试…...
计算机网络安全基础知识3:网站漏洞,安装phpstudy,安装靶场漏洞DVWA,搭建一个网站
计算机网络安全基础知识3:网站漏洞,安装phpstudy,安装靶场漏洞DVWA,搭建一个网站 2022找工作是学历、能力和运气的超强结合体,遇到寒冬,大厂不招人,可能很多算法学生都得去找开发,测…...
大话数据结构-迪杰斯特拉算法(Dijkstra)和弗洛伊德算法(Floyd)
6 最短路径 最短路径,对于图来说,是两顶点之间经过的边数最少的路径;对于网来说,是指两顶点之间经过的边上权值之和最小的路径。路径上第一个顶点为源点,最后一个顶点是终点。 6.1 迪杰斯特拉(Dijkstra&am…...
2023年全国最新食品安全管理员精选真题及答案10
百分百题库提供食品安全管理员考试试题、食品安全员考试预测题、食品安全管理员考试真题、食品安全员证考试题库等,提供在线做题刷题,在线模拟考试,助你考试轻松过关。 91.实施日常检查,如果违反关键项的,应当即作出如…...
Unity常见面试题详解(持续更新...)
一丶声明、定义、实例化、初始化 1、首先我们来讨论在C/C中的声明和定义.. 1)我们先从函数声明和定义说起... 一般我们在C里都会先定义一个函数,然后再Main函数前将函数声明,比如: //函数声明 int Add(int);int Main {} //函数…...
java高级篇之三大性质总结:原子性、可见性以及有序性
1. 三大性质简介 在并发编程中分析线程安全的问题时往往需要切入点,那就是两大核心:JMM抽象内存模型以及happens-before规则(在这篇文章中已经经过了),三条性质:原子性,有序性和可见性。关于sy…...
真涨脸,我用 Python 为朋友自动化整理表格
今天,在工作的时候,我的美女同事问我有没有办法自动生成一个这样的表格: 第一列是院校科目,第二列是年份,第三列是数量。 这张表格是基于这一文件夹填充的,之前要一个文件夹一个文件夹打开然后手动填写年份…...
MySQL学习笔记(1.操作数据库与数据的SQL)
1. 下载安装 参照:MySQL8.0下载安装_凯尔萨厮的博客-CSDN博客 2. MySQL启动与停止 方式(1).我的电脑>右键>管理>服务和应用程序>服务>(或在windows搜索栏输入services.msc) 找到MySQL80,右键启动或停止 方式(2…...
C++——特殊类设计
目录 不能被拷贝的类 只能在堆上创建对象的类 只能在栈上创建对象的类 不能被继承的类 只能创建一个对象的类(单例模式) 饿汉模式 懒汉模式 单例对象释放问题 不能被拷贝的类 C98:将拷贝构造函数与赋值运算符重载只声明不定义,并且将其访问权…...
Scratch少儿编程案例-植物大战僵尸-趣味角色版
专栏分享 点击跳转=>Unity3D特效百例点击跳转=>案例项目实战源码点击跳转=>游戏脚本-辅助自动化点击跳转=>Android控件全解手册点击跳转=>Scratch编程案例👉关于作者...
Vue的路由守卫
对于绝大部分的网站而言,都是有个人主页的,但是你如果没登陆的话,还能访问个人主页吗? 从逻辑上来讲,那肯定是不行的。 所以,要怎么阻止没登录状态下去访问个人主页呢? 就是利用路由守卫&#x…...
【算法】151. 反转字符串中的单词
链接:https://leetcode.cn/problems/reverse-words-in-a-string/给你一个字符串 s ,请你反转字符串中 单词 的顺序。单词 是由非空格字符组成的字符串。s 中使用至少一个空格将字符串中的 单词 分隔开。返回 单词 顺序颠倒且 单词 之间用单个空格连接的结…...
Azure AI基础到实战(C#2022)-认知服务(2)
目录 ComputerVisionClient Class定义构造函数属性上一节例子Task.Wait 方法其它部分分析winform调用认知服务代码剖析1、调用参数2、定义ComputerVisionClient对象,准备调用 REST API3、Authenticate4、调用REST API,这是重点和关键(1)Lambda 表达式和匿名函数(2)async(3)…...
并发就一定快吗?答:肯定不是啊
文章目录一、多线程概念1.1 程序的并发与并行1.1.1 程序的并行1.1.2 程序的并发1.2 进程与线程1.2.1 进程1.2.2 线程1.2.3 多线程并发就一定快吗?答案直接戳这里👉:多线程并发就一定快吗? 一、多线程概念 在实际应用中ÿ…...
做网站维护师傅带要学多久/最近一周的新闻热点事件
之前我们在计算神经网络预测结果的时候我们采用了一种正向传播方法,我们从第一层开始正向一层一层进行计算,直到最后一层的ℎ? (?)。 现在,为了计算代价函数的偏导数我们需要采用一种反向传播算法,也就是 首先计算最后一层的误差…...
兰州新站seo/友情链接管理系统
Apple ProRes 编解码器提供独一无二的多码流实时编辑性能、卓越图像质量和降低的存储率组合。Apple ProRes 编解码器充分利用多核处理,并具有快速、降低分辨率的解码模式。 所有 Apple ProRes 编解码器都支持全分辨率的任意帧尺寸(包括 SD、HD、2K、4K 和…...
wordpress目录怎么制作/厦门关键词排名优化
下载地址:https://github.com/D35m0nd142/LFISuite 利用该工具首先可获取到一个LFIshell,再通过nc即可获取到一个反向连接!转载于:https://blog.51cto.com/eth10/1956251...
wordpress用户积分/百度图片搜索入口
SpringBoot 中 RequestBody的正确使用方法 最近在接收一个要离职同事的工作,接手的项目是用SpringBoot搭建的,其中看到了这样的写法: [java] view plaincopy RequestMapping("doThis") public String doThis(HttpServletRequest r…...
有没有专门做胜负彩的网站/营销是什么意思
安装opencv文件时若需要cmake编译,如果中间出现 解决办法是: 在opencv的文件中找到包含cmakelist.txt的文件夹,把where is the source code:的路径改成它。 然后在where to build the binaries 的路径中写上任何一个不存在的路径,…...
营销型网站建设发难/在线科技成都网站推广公司
浙江省信息技术会考高考知识点2011年浙江省信息技术考试知识点必修-信息技术基础第一单元 信息技术基础1. 信息及其特征信息是指数据、信号、消息中包含的意义。信息的特征: ①信息的表示、传播、存储必须依附于某种载体。 ②信息是可以加工处理的③信息…...