• <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命令行提示符——“[\[][^]\[]*[]][#$] ”或“\[[^]\[]*][#$] ”。
            91精品国产91久久久久久青草| 国产精品视频久久久| 国产亚洲成人久久| 久久夜色撩人精品国产| 亚洲精品乱码久久久久久中文字幕 | 69久久夜色精品国产69| 国产精品免费久久久久久久久 | 99久久免费国产精品特黄| 青青草原精品99久久精品66| 成人精品一区二区久久久| 精品国产乱码久久久久久呢 | 香蕉久久夜色精品国产2020| 99久久久国产精品免费无卡顿| 久久AAAA片一区二区| 777米奇久久最新地址| 伊人 久久 精品| 久久青草国产精品一区| 伊人久久大香线蕉综合5g| 国产成人久久精品麻豆一区| 久久无码人妻一区二区三区午夜| 久久久精品久久久久特色影视| 精品无码久久久久国产| 精品综合久久久久久98| 久久久久99精品成人片三人毛片| 精品久久久久久无码专区不卡| 亚洲国产成人精品久久久国产成人一区二区三区综 | 久久这里只有精品18| 女人高潮久久久叫人喷水| 丰满少妇人妻久久久久久4| 欧美精品一本久久男人的天堂| 久久久久亚洲AV无码网站| 亚洲va国产va天堂va久久| 国产亚洲精品久久久久秋霞| 亚洲日本va午夜中文字幕久久| 久久精品不卡| 色99久久久久高潮综合影院| 久久亚洲国产精品123区| 久久午夜综合久久| 亚洲人AV永久一区二区三区久久| 国产精品99久久久久久www| 精品久久久久一区二区三区 |