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 多线程并发就一定快吗?答案直接戳这里👉:多线程并发就一定快吗? 一、多线程概念 在实际应用中ÿ…...
网站推广明细报价表/搜索引擎平台
作为一名全职的Go语言作家和老师,我花了很多时间和学生们一起,帮助他们写出更清晰、更好、更有用的Go程序。我发现,我给他们的建议可以归纳总结为一套通用原则,在这里我将这些原则分享给大家。1、你应该是无聊的Go社区喜欢共识&am…...
网站图片命名规范/如何建立公司网站网页
一、Md5()加密算法 单项加密,无法解密。 md5(string $str[, bool $raw_output false]); //计算md5散列值 对于可选参数raw_output。如果设置为true,那么MD5报文摘要将以16字节长度的原始二进制格式返回。false返回32位字符十六进制数字形式返回散列…...
网站开发美工绩效考核/seo公司推广宣传
基于光流法相位提取算法原理的参考文献为:点击打开链接%% *******************************************%% **********************************************clear;close all;clc;N 512;xmax 1;ymax 1;delta [0,pi/3];x linspace(-xmax,xmax,N);y linspace(-y…...
郑州做网站的多不多/百度知道登录
目录 一.什么是火墙 二. iptables和filrewalld两种工具的切换 三.firewalld 1.火墙的域 2.设定原理及数据存储 3.firewalld 的管理命令 4.firewalld高级规则 三.iptables 1.五条链 2.三张表 3.iptables 4.数据包状态 5.dnat,snat 一.什么是火墙 Natfilter 是集成到lin…...
wordpress mac下载文件/免费行情软件网站下载大全
概要 风格转换已成功应用于照片,生成逼真的西方绘画。然而,由于中西绘画技法的内在差异,直接套用已有的方法,对中国水墨画风格的转换并不能产生令人满意的效果。本文提出了一种基于ChipGAN的端到端( end-to-end&am…...
高要网站制作/如何在百度上发布自己的文章
如果电商企业想将业务提升到一个新的水平,则应考虑接入第三方快递查询API接口。快递查询API接口提供了很多好处,并且可以为电商企业、微商带来强大的竞争优势。因为相对于独立一家家对接各个快递公司的服务接口,这种第三方快递查询API接口支持…...