C++11--正则表达式<regex>
/*
正则表达式:一个指定的模式用来对文本中的字符串提供精确且灵活的匹配
*/
#include <regex>
using namespace std;
int main() {
string str;
while (true) {
cin >> str;
//regex e("abc.", regex_constants::icase); // . 表示除了换行符之外任意字符
//regex e("abc?"); // ? 0个或者1个前面的字符
//regex e("abc*"); // * 0个或多个前面的字符
//regex e("abc+"); // + 1个或多个前面的字符
//regex e("ab[cd]*"); // [...] 方括号中任意字符
//regex e("ab[^cd]*"); // [^...] 任意不在方括号中的字符
//regex e("ab[cd]{3,5}");
//regex e("abc|de[\]fg]"); // | 或者
//regex e("(abc)de+\\1"); // \1 第1个子串
//regex e("(ab)c(de+)\\2\\1");
//regex e("[[:w:]]+@[[:w:]]+\.com"); // [[:w:]] :字母,数字,下划线
//regex e("abc.$"); // $ 行尾
regex e("^abc.+", regex_constants::grep); // ^ 行首,切换正则表达式语法
//bool match = regex_match(str, e); //str和e精确匹配
bool match = regex_search(str, e); //str中中包含e
cout << (match? "Matched" : "Not matched") << endl << endl;
}
}
/*
正则表达式语法:
ECMAScript //C++默认
basic
extended
awk
grep
egrep
regex e("^abc.+", regex_constants::grep); // 切换语法
*/
/*************** 处理子表达式 *****************/
/*
std::match_results<> 储存详细的匹配Store the detailed matches
smatch string类型的详细的匹配Detailed match in string
smatch m;
m[0].str() 整个匹配的字符串 (同m.str(), m.str(0))
m[1].str() 第1个子串(同m.str(1))
m[2].str() 第2个子串
m.prefix() 所有匹配字符串之前的部分
m.suffix() 所有匹配字符串之后的部分
*/
int main() {
string str;
while (true) {
cin >> str;
smatch m; // typedef std::match_results<string>
regex e("([[:w:]]+)@([[:w:]]+)\.com");
bool found = regex_search(str, m, e); //只返回第一个匹配
cout << "m.size() " << m.size() << endl; //size()==子匹配个数+1
for (int n = 0; n< m.size(); n++) {
cout << "m[" << n << "]: str()=" << m[n].str() << endl;
cout << "m[" << n << "]: str()=" << m.str(n) << endl;
cout << "m[" << n << "]: str()=" << *(m.begin()+n) << endl;
}
cout << "m.prefix().str(): " << m.prefix().str() << endl;
cout << "m.suffix().str(): " << m.suffix().str() << endl;
}
}
// 多个匹配的情况
/**************** Regex Iterator ******************/
int main() {
cout << "Hi" << endl;
string str;
while (true) {
cin >> str;
regex e("([[:w:]]+)@([[:w:]]+)\.com");
sregex_iterator pos(str.cbegin(), str.cend(), e);
sregex_iterator end; // 默认构造定义了past-the-end迭代器
for (; pos!=end; pos++) {
cout << "Matched: " << pos->str(0) << endl;
cout << "user name: " << pos->str(1) << endl;
cout << "Domain: " << pos->str(2) << endl;
cout << endl;
}
cout << "=============================\n\n";
}
}
/**************** Regex Token Iterator ******************/
int main() {
cout << "Hi" << endl;
//string str = "Apple; Orange, {Cherry}; Blueberry";
string str = "boq@yahoo.com, boqian@gmail.com; bo@hotmail.com";
//regex e("[[:punct:]]+"); // 空格,数字,字母以外的可打印字符
//regex e("[ [:punct:]]+");
regex e("([[:w:]]+)@([[:w:]]+)\.com");
sregex_token_iterator pos(str.cbegin(), str.cend(), e, 0); //最后一个参数指定打印匹配结果的哪一部分,0表达整个匹配字符串,1表示第1个子串,-1表示没有匹配的部分
sregex_token_iterator end; // 默认构造定义了past-the-end迭代器
for (; pos!=end; pos++) {
cout << "Matched: " << *pos << endl;
}
cout << "=============================\n\n";
cin >> str;
}
/**************** regex_replace ******************/
// 将匹配的字符串部分替换
int main() {
cout << "Hi" << endl;
string str = "boq@yahoo.com, boqian@gmail.com; bo@hotmail.com";
regex e("([[:w:]]+)@([[:w:]]+)\.com");
regex e("([[:w:]]+)@([[:w:]]+)\.com", regex_constants::grep|regex_constants::icase );
//cout << regex_replace(str, e, "$1 is on $2");
cout << regex_replace(str, e, "$1 is on $2", regex_constants::format_no_copy|regex_constants::format_first_only);//format_no_copy不匹配的字符部分不拷贝到新串,只匹配第一个
cout << regex_replace(str, e, "$1 is on $2"); // $1表示第一个子串
std::cin >> str;
}
C++11--正则表达式<regex>的更多相关文章
- c++11 正则表达式基本使用
c++ 11 正则表达式 常用的方法 regex_match regex_search regex_replace 等. regex_match 要求正则表达式必须与模式串完全匹配,例如: strin ...
- C++11 | 正则表达式(4)
C++11还支持正则表达式里的子表达式(也叫分组),用sub_match这个类就行了. 举个简单的例子,比如有个字符串"/id:12345/ts:987697413/user:678254& ...
- (四)boost库之正则表达式regex
(四)boost库之正则表达式regex 正则表达式可以为我们带来极大的方便,有了它,再也不用为此烦恼 头文件: #include <boost/regex.hpp> 1.完全匹配 std ...
- 【正则表达式1】C++11正则表达式
https://www.cnblogs.com/pukaifei/p/5546968.html [正则表达式1]C++11正则表达式 头文件 #include <regex> rege ...
- 请写出正则表达式(regex),取得下列黄色部分的字符串 TEL: 02-236-9655/9659 FAX:02-236-9654 (黄色部分即02-236-9655/9659 ) ( 测试面试题)
请写出正则表达式(regex),取得下列黄色部分的字符串 TEL: 02-236-9655/9659 FAX:02-236-9654 答: package test1; import java.uti ...
- C#正则表达式Regex常用匹配
使用Regex类需要引用命名空间:using System.Text.RegularExpressions; 利用Regex类实现验证 示例1:注释的代码所起的作用是相同的,不过一个是静态方法,一个是 ...
- C#正则表达式Regex类的用法
C#正则表达式Regex类的用法 更多2014/2/18 来源:C#学习浏览量:36891 学习标签: 正则表达式 Regex 本文导读:正则表达式的本质是使用一系列特殊字符模式,来表示某一类字符串, ...
- C#正则表达式Regex类
C#正则表达式Regex类的使用 C#中为正则表达式的使用提供了非常强大的功能,这就是Regex类.这个包包含于System.Text.RegularExpressions命名空间下面,而这个命名空间 ...
- boost 正则表达式 regex
boost 正则表达式 regex 环境安装 如果在引用boost regex出现连接错误,但是引用其他的库却没有这个错误,这是因为对于boost来说,是免编译的,但是,正则这个库 是需要单独编译 ...
- python进阶11 正则表达式
python进阶11 正则表达式 一.概念 #正则表达式主要解决什么问题? #1.判断一个字符串是否匹配给定的格式,判断用户提交的又想的格式是否正确 #2.从一个字符串中按指定格式提取信息,抓取页面中 ...
随机推荐
- [LeetCode&Python] Problem 258. Add Digits
Given a non-negative integer num, repeatedly add all its digits until the result has only one digit. ...
- Gym - 101002K:YATP (树分治+二分+斜率优化)
题意:给定带点权边权的树,定义路径的花费=路径边权和e+起点点权w[s]*终点点权w[t].N<2e5,e,w<1e6: 思路:首先,需要树分治. 然后得到方程dp[i]=min{ dis ...
- java-接口的成员特点
1.成员变量: - 只能是常量,并且是静态的.公共的. - 默认修饰符:public static final - 建议:自己手动给出. 2.构造方法:接口没有构造方法. 3.成员方法: - 只能是抽 ...
- Excel列名和列序号转换
大家有没有留意过Excel表格中列名的规律呢?是这样的:A B C ... Y Z AA AB AC ... AY AZ BA BB BC ... BY BZ ... ZZ ... AAA ... 如 ...
- 非系统服务如何随系统启动时自动启动(rc.local加了可执行权限,仍然没有生效)
我们知道,例如我们直接yum 安装的httpd mysqld之类的服务可以直接systemctl enable mysql使服务自动启动,但是,我们应该关心的是但是的那部分 例如nginx,我的话,我 ...
- java中的数据结构
1.链表的使用 使用时需要import java.util.List 和 java.util.ArrayList //返回list中的元素个数 int size(); //判断list中是否包含元素, ...
- Android.bp学习笔记
1.Android.bp简介 Android 7.0之后希望用Android.bp替换Android.mk,bp简单的配置更方便Ninja 文件的产生,而Blueprint和Soong 就此产生.An ...
- cocos2d-x游戏开发 跑酷(三) 人物跑动
原创.转载请注明出处:http://blog.csdn.net/dawn_moon/article/details/21245881 好吧.最终要跑起来了. 要实现跑酷须要用到帧动画,什么是帧动画,不 ...
- java项目中异常处理情况
一,基本概念 异常是程序在运行时出现的不正常情况.是Java按照面向对象的思想将问题进行对象封装.这样就方便于操作问题以及处理问题. 异常处理的目的是提高程序的健壮性.你可以在catch和fin ...
- pdf.js 的使用
现在的浏览器基本都支持直接把 pdf 文件拖到浏览器就可以打开,不用下载pdf阅读插件,但是在写网页的时候遇到了 pdf 文件怎么办呢,有两种解决办法,一种是用 falsh 来向用户展示,优点就是支持 ...