• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 26, comments - 2, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            工作中經(jīng)常需要在正則表達(dá)式中使用方括號(hào),比如匹配Linux系統(tǒng)命令行提示符“[root@localhost ~]# ”。在python中,可以使用正則表達(dá)式“[\[][^\[\]]*[\]][#|$] ”進(jìn)行匹配,但在regex中此正則表達(dá)式無法正確匹配。
            由于man手冊(cè)中缺少對(duì)方括號(hào)轉(zhuǎn)義的介紹,本文對(duì)regex中方括號(hào)的使用進(jìn)行測(cè)試,測(cè)試程序如下:

            #include <stdio.h>
            #include 
            <string.h>

            #include 
            <sys/types.h>
            #include 
            <regex.h>

            int main(int argc, char** argv)
            {
                    
            char * pattern, *mstr;
                    
            int x, z, lno = 0, cflags = REG_EXTENDED;
                    
            char ebuf[128], lbuf[256], format[32];
                    regex_t reg;
                    regmatch_t pm[
            10];
                    
            const size_t nmatch = 10;

                    pattern 
            = argv[1];
                    z 
            = regcomp(&reg, pattern, cflags);

                    
            if (z != 0)
                    
            {
                            regerror(z, 
            &reg, ebuf, sizeof(ebuf));
                            fprintf(stderr, 
            "%s: pattern '%s' \n",ebuf, pattern);
                            regfree(
            &reg);
                            
            return 1;
                    }


                    
            while(fgets(lbuf, sizeof(lbuf), stdin))
                    
            {
                            
            ++lno;
                            
            if ((z = strlen(lbuf)) > 0 && lbuf[z-1]== '\n') lbuf[z - 1= 0;

                            z 
            = regexec(&reg, lbuf, nmatch, pm, 0);
                            
            if (z == REG_NOMATCH)
                            
            {
                                    printf(
            "not match\n");
                                    
            continue;
                            }

                            
            else if (z != 0)
                            
            {
                                    regerror(z, 
            &reg, ebuf, sizeof(ebuf));
                                    fprintf(stderr, 
            "%s: regcom('%s')\n",
                                                    ebuf, lbuf);
                                    
            return 2;
                            }


                            
            if (pm[0].rm_so!=-1)
                                    printf(
            "%04d: %s\n", lno, lbuf);
                            
            for (x = 0; x < nmatch && pm[x].rm_so != -1++ x)
                            
            {
                                    mstr 
            = strndup(lbuf + pm[x].rm_so, pm[x].rm_eo-pm[x].rm_so);
                                    printf(
            " $%d: %s\n", x, mstr);
                                    free(mstr);
                            }

                            fflush(stdout);

                    }


                    regfree(
            &reg);
                    
            return 0;
            }
            下面是對(duì)正則表達(dá)式“[\[][^\[\]]*[\]][#|$] ” 的測(cè)試,顯然不符合要求。
            ./testreg "[\[][^\[\]]*[\]][#|$] "  
            [root@localhost bin]# 
            not match
            [a\]# 
            0005: [a\]# 
             $
            0: [a\]# 
            從簡(jiǎn)單的開始先測(cè)試左括號(hào)“[”的匹配:
            ./testreg "[\[]+"
            a
            not match
            [
            0002: [
             $
            0: [
            [root@localhost bin]# 
            0003: [root@localhost bin]# 
             $
            0: [
            再測(cè)試右括號(hào)“]”:
            ./testreg "[\]]+"
            ]
            not match
            \]  
            0002: \]
             $
            0: \]
            -----------------
            .
            /testreg "[]]+"
            ]]
            0001: ]]
             $
            0: ]]
            兩個(gè)簡(jiǎn)單的正則表達(dá)式可以看出:regex中左方括號(hào)需要轉(zhuǎn)義,右方括號(hào)不需要轉(zhuǎn)義。
            下面我們?cè)賮頊y(cè)試匹配一下任意非方括號(hào)字符:
            ./testreg "[^\[]]+" //對(duì)[轉(zhuǎn)義,不對(duì)]轉(zhuǎn)義
            [abc]
            0001: [abc]
             $
            0: c]
            .
            /testreg "[^\[\]]+" //對(duì)[和]轉(zhuǎn)義
            [abc]
            0001: [abc]
             $
            0: c]
            .
            /testreg "[^]\[]+" //對(duì)[轉(zhuǎn)義,不對(duì)]轉(zhuǎn)義,且把]放在^后使]不與前面的[匹配
            [abc]
            0001: [abc]
             $
            0: abc
            通過上面測(cè)試可以得出正確的正則表達(dá)式來匹配Linux命令行提示符——“[\[][^]\[]*[]][#$] ”或“\[[^]\[]*][#$] ”。
            亚洲欧洲中文日韩久久AV乱码| 久久妇女高潮几次MBA| 久久精品国产亚洲AV香蕉| 99久久婷婷国产一区二区| 99国产精品久久| 久久精品国产第一区二区三区| 精产国品久久一二三产区区别| 久久精品无码一区二区app| 国产视频久久| 久久艹国产| 伊人久久成人成综合网222| 久久国产视频网| 亚洲国产成人精品女人久久久| 久久本道久久综合伊人| 亚洲国产成人精品91久久久| 热RE99久久精品国产66热| 久久亚洲精品无码观看不卡| 一本色道久久88综合日韩精品| 国产精品乱码久久久久久软件 | 精品久久人人做人人爽综合| 国产精品久久久福利| 久久91精品综合国产首页| 亚洲精品无码专区久久同性男| 99久久香蕉国产线看观香| 亚洲伊人久久大香线蕉综合图片 | 久久超乳爆乳中文字幕| 久久精品人人做人人爽电影| 久久九九免费高清视频| 一本一道久久综合狠狠老| 国产精品久久久久jk制服| 国产精品狼人久久久久影院| 亚洲国产精品成人AV无码久久综合影院 | 精品久久久久久中文字幕人妻最新 | 国产精品美女久久久久av爽| 亚洲精品国产第一综合99久久| 久久er99热精品一区二区| 色综合久久综合网观看| 久久亚洲国产精品成人AV秋霞 | 国产福利电影一区二区三区,免费久久久久久久精 | 狠狠色丁香婷婷综合久久来来去| 久久天天躁狠狠躁夜夜躁2014|