搜尋

首頁  >  問答  >  主體

正则表达式 - c++标准库中没有关于正则匹配字符串的函数么?

我想实现的是查找满足正则条件的字符串,google了一下,发现都是用的boost中的函数,难道标准库中没有相关函数么?

巴扎黑巴扎黑2817 天前616

全部回覆(6)我來回復

  • 迷茫

    迷茫2017-04-17 11:04:55

    在Linux下你可以很方便的使用regex.h提供的庫。我先貼一段代碼展示一下RE在C語言裏是怎麼用的
    ,比較粗略點

    #include<stdio.h>
    #include<sys/types.h>
    #include<regex.h>
    #include<memory.h>
    #include<stdlib.h>
    
    int main()
    {
     
        char *bematch = "hhhericchd@gmail.com";
        char *pattern = "h{3,10}(.*)@.{5}.(.*)";
        char errbuf[1024];
        char match[100];
        
        regex_t reg;
        int err,nm = 10;
        regmatch_t pmatch[nm];
     
        if(regcomp(&reg,pattern,REG_EXTENDED) < 0){
            regerror(err,&reg,errbuf,sizeof(errbuf));
            printf("err:%s\n",errbuf);
        }
     
        err = regexec(&reg,bematch,nm,pmatch,0);
        if(err == REG_NOMATCH){
            printf("no match\n");
            exit(-1);
        }else if(err){
            regerror(err,&reg,errbuf,sizeof(errbuf));
            printf("err:%s\n",errbuf);
            exit(-1);
        }
     
        for(int i=0;i<10 && pmatch[i].rm_so!=-1;i++){
            int len = pmatch[i].rm_eo-pmatch[i].rm_so;
            if(len){
                memset(match,'
    "h{3,10}(.*)@.{5}.(.*)"
    ',sizeof(match)); memcpy(match,bematch+pmatch[i].rm_so,len); printf("%s\n",match); } } return 0; }

    我打算看看一個郵件地址是否匹配我所提供的pattern。這個郵件地址是
    hhhericchd@gmail.com patern為

    rrreee

    回覆
    0
  • 阿神

    阿神2017-04-17 11:04:55

    • C 98裏肯定是沒有正則庫的
    • C 0x有std::regex,目前隻有VS2010 支持 GCC(libstd )不支持
    • PCRE/PCRE 是比較老牌的C/C 正則庫,跨平台
    • linux下glibc裏有正則庫,直接include "regex.h"
    • windows下可以用com調vbscript的IRegExp2正則接口,任何版本windows適用,不需要任何額外依賴,速度也很快
    • boost裏也有正則,但是boost庫東西太多,相當臃腫

    回覆
    0
  • 高洛峰

    高洛峰2017-04-17 11:04:55

    你可以用linux自帶的regex庫。

    回覆
    0
  • 阿神

    阿神2017-04-17 11:04:55

    貌似隻有一些第三方的,微軟有一個,boost的應該更通用一點吧.

    回覆
    0
  • 伊谢尔伦

    伊谢尔伦2017-04-17 11:04:55

    pcre 是個著名的正則庫. php就在用它

    回覆
    0
  • 大家讲道理

    大家讲道理2017-04-17 11:04:55

    c 11的<regex>
    Eg:

    #include <regex>
    #include <iostream>
    using namespace std;
    //匹配手机号码
    int main() {
        regex reg;
        regex_constants::syntax_option_type fl = regex_constants::icase;
        reg.assign("\b1[35][0-9]\d{8}|147\d{8}|1[8][01236789]\d{8}\b", fl);
        bool found1 = regex_match("13536921192", reg);
        cout<<found1<<endl;
    }

    參見:http://www.codeceo.com/article/cpp11-regex-code.html

    回覆
    0
  • 取消回覆