正则表达式
-
在编写处理字符串的程序或网页时,经常会有查找符合某些复杂规则的字符串的需要。正则表达式: 就是用于描述这些规则的工具。换句话说,正则表达式就是记录文本规则的代码。 -
元字符
代码 | 说明 |
---|
. | 匹配除换行符以外的任意字符 | \w | 匹配字母或数字或下划线或汉字 | \s | 匹配任意的空白符 | \d | 匹配数字 | \b | 匹配单词的开始或结束 | ^ | 匹配字符串的开始 | $ | 匹配字符串的结束 |
-
字符转移 如果你想查找元字符本身的话,比如你查找.,或者*,就出现了问题:你没办法指定它们,因为它们会被解释成别的意思。这时你就得使用\来取消这些字符的特殊意义。因此,你应该使用\.和\*。当然,要查找\本身,你也得用\。 -
重复
代码/语法 | 说明 |
---|
* | 重复零次或更多次 | + | 重复一次或更多次 | ? | 重复零次或一次 | {n} | 重复n次 | {n,} | 重复n次或更多次 | {n,m} | 重复n到m次 |
-
字符类
- 要想查找数字,字母或数字,空白是很简单的,因为已经有了对应这些字符集合的元字符,但是如果你想匹配没有预定义元字符的字符集合(比如元音字母a,e,i,o,u),应该怎么办?
- 在方括号里列出它们就行了,像[aeiou]就匹配任何一个英文元音字母,[.?!]匹配标点符号(.或?或!)。
- 也可以轻松地指定一个字符范围,像[0-9]代表的含意与\d就是完全一致的:一位数字;同理[a-z0-9A-Z_]也完全等同于\w(如果只考虑英文的话)。
- 下面是一个更复杂的表达式:(?0\d{2}[) -]?\d{8}。
- 这个表达式可以匹配几种格式的电话号码,像(010)88886666,或022-22334455,或02912345678等。我们对它进行一些分析吧:首先是一个转义字符(,它能出现0次或1次(?),然后是一个0,后面跟着2个数字(\d{2}),然后是)或-或空格中的一个,它出现1次或不出现(?),最后是8个数字(\d{8})。
-
反义
代码/语法 | 说明 |
---|
\W | 匹配任意不是字母,数字,下划线,汉字的字符 | \S | 匹配任意不是空白符的字符 | \D | 匹配任意非数字的字符 | \B | 匹配不是单词开头或结束的位置 | [^x] | 匹配除了x以外的任意字符 | [^aeiou] | 匹配除了aeiou这几个字母以外的任意字符 |
cpp标准库之 std::regex 类
- C++标准库中常用正则表达式类主要包含如下5组:
std::regex_match 函数模板,正则表达式完全匹配整个字符串序列。如果匹配成功,他还可以获取捕获组,单词匹配。std::regex_search 函数模板,在字符串中搜索正则表达式匹配的子,如果搜索成功,他还可以获取捕获组,单词搜索。std::regex_replace 函数模板,多次搜索整个正则表达式(不考虑捕获组),然后替换正则表达式匹配到的结果,多次替换。std::regex_interator 类模板,用于多次重复匹配,不分组,只进行多次匹配整个正则表达式,可获取整个正则表达式的结果,多次匹配。std::regex_token_interator 类模板,用于多次匹配正则表达式,他可以获取整个正则表达式的结果以及正则表达式的前缀和捕获组,多次匹配。 - 正则表达式模板的使用:
- Match: 将整个string拿来匹配某个regex.
- Search: 查找某个string中与regex吻合的部分.
- Replace: 将与正则表达式吻合的第一个(或者后续所有的)子序列替换掉.
- Tokenize: 切分即通过指定来切分出来我们感兴趣的正则表达式匹配到的内容
c++ 目录流 DIR,dirent使用
案例使用:
void GetFilesName(const std::string& img_dir_path,std::vector<std::string> &img_file_paths)
{
DIR* dir;
if ((dir = opendir(img_dir_path.c_str())) == nullptr) {
throw std::runtime_error("directory " + img_dir_path + " does not exist");
}
dirent* dp;
for (dp = readdir(dir); dp != nullptr; dp = readdir(dir)) {
const std::string img_file_name = dp->d_name;
if (img_file_name == "." || img_file_name == "..") {
continue;
}
img_file_paths.push_back(img_dir_path + "/" + img_file_name);
}
closedir(dir);
std::sort(img_file_paths.begin(), img_file_paths.end());
}
- 结构体 dirent 中的成员 d_type 表示读取的目录中的文件的类型,d_name 表示读取的目录中的文件的名字。
struct __dirstream
{
void *__fd;
char *__data;
int __entry_data;
char *__ptr;
int __entry_ptr;
size_t __allocation;
size_t __size;
__libc_lock_define (, __lock)
};
typedef struct __dirstream DIR;
- 函数
DIR *opendir(const char *pathname) ,即打开文件目录,返回的就是指向DIR结构体的指针,而该指针由以下几个函数使用:struct dirent *readdir(DIR *dp);
void rewinddir(DIR *dp);
int closedir(DIR *dp);
long telldir(DIR *dp);
void seekdir(DIR *dp,long loc);
#include <dirent.h>
struct dirent
{
long d_ino;
off_t d_off;
unsigned short d_reclen;
unsigned char d_type;
char d_name [NAME_MAX+1];
|