• <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>

            boost::regex

            Posted on 2008-07-20 09:45 RichardHe 閱讀(925) 評論(0)  編輯 收藏 引用 所屬分類: [轉(zhuǎn)]

            boost::regex

            • boost::regex的用法

                    bool validate_card_format(const std::string s)
                    {
                       static const boost::regex e("(\\d{4}[- ]){3}\\d{4}");
                       return regex_match(s, e);
                    }

            • boost::regex的默認(rèn)正則表達(dá)式語法是perl語法

                    boost::regex支持perl regular表達(dá)式、POSIX-Extended regular表達(dá)式和POSIX-Basic Regular表達(dá)式,但默認(rèn)的表達(dá)式語法是perl語法,如果要使用其余兩種語法需要在構(gòu)造表達(dá)式的時(shí)候明確指定。

                    例如,下面兩種方法效果相同
                    // e1 is a case sensitive Perl regular expression: 
                    // since Perl is the default option there's no need to explicitly specify the syntax used here:
                    boost::regex e1(my_expression);
                    // e2 a case insensitive Perl regular expression:
                    boost::regex e2(my_expression, boost::regex::perl|boost::regex::icase);

            • perl正則表達(dá)式語法

                    perl正則表達(dá)式語法可參見《perl語言入門》第7、8、9章或boost的文檔。這里列出的語法是不全面的,而且部分說明可能并不清楚。

                    . 任意字符;使用match_no_dot_null標(biāo)志時(shí)不匹配NULL字符; 使用match_not_dot_newline時(shí)不匹配換行字符

                    ^ 匹配行的開始
                    $ 匹配行的結(jié)束
                    * 重復(fù)零次或則更多,例如a*b可匹配b,ab,aab,aaaaaaab
                    + 重復(fù)一次以上,例如a+b可匹配ab,aab,aaaaaaaab。但不能匹配b了
                    ? 零次或則一次,例如ca?b匹配cb,cab但不匹被caab    
                    a{n} 匹配字符'a'重復(fù)n次
                    a{n,},字符a重復(fù)n次以上(含n次)
                    a{n,m} a重復(fù)n到m次(含)

                    *?   匹配前一個(gè)原子零次以上
                    +?   匹配前一個(gè)原子一次以上
                    ??   匹配前一個(gè)原子零次以上
                    {n,}?  匹配前一個(gè)原子n次以上(含)
                    {n,m?  匹配前一個(gè)原子n到m次(含)

                    | 或操作,例如ab(d|ef)匹配abd或則abef
                    [] 字符集操作,例如[abc]將匹配任何單個(gè)字符'a','b','c'
                    [a-d],表示a、b、c、d
                    ^否操作,例如[^a-c]表示a至c之外的所有字符

            • boost::regex對unicode編碼的支持

                    boost::regex使用ICU來實(shí)現(xiàn)對unicode及unicode變種的支持,這需要在編譯boost的時(shí)候指出是否使 用ICU以及ICU所在的目錄。否則編譯出來的boost::regex不支持unicode編碼。其中boost::wregex支持unicode編 碼的搜索,如果要搜索UTF-8、UTF-16、UFT-32編碼的字符串,則要用boost::u32regex。注意boost::wregex只能 支持unicode編碼,不能支持uft編碼。

            • 搜索時(shí)如何忽略大小寫

                    如果要在搜索時(shí)忽略大小寫(即大小寫不敏感),則要用到表達(dá)式選項(xiàng)boost::regex::icase,例 如: boost::regex e2(my_expression, boost::regex::perl|boost::regex::icase);

            posts - 94, comments - 138, trackbacks - 0, articles - 94

            Copyright © RichardHe

            久久精品国产精品国产精品污| 久久精品国产精品亚洲下载| 久久精品视频一| 婷婷久久久亚洲欧洲日产国码AV| 久久久久久国产精品免费无码| 久久久久久亚洲精品影院| 亚洲欧美成人久久综合中文网| 亚洲欧美另类日本久久国产真实乱对白| 久久国产亚洲精品麻豆| 国产ww久久久久久久久久| 日韩va亚洲va欧美va久久| 久久丫精品国产亚洲av不卡 | 久久久久无码国产精品不卡| 久久久久人妻一区精品| 久久A级毛片免费观看| 亚洲综合久久夜AV | 色综合久久最新中文字幕| 狠狠色丁香婷婷久久综合五月| 久久国产精品一国产精品金尊| 国产亚洲成人久久| 思思久久99热免费精品6| 久久精品国产秦先生| 伊人久久大香线蕉av不变影院| 九九热久久免费视频| 亚洲愉拍99热成人精品热久久| 日产久久强奸免费的看| 精品综合久久久久久888蜜芽| 色妞色综合久久夜夜| 久久久久久国产精品无码下载| 久久久久亚洲AV无码麻豆| 亚洲欧洲精品成人久久奇米网| 国产精品成人99久久久久 | 久久99精品国产99久久| 亚洲精品国产美女久久久| 2021国产精品午夜久久| 久久天天躁狠狠躁夜夜av浪潮| 国产精品热久久无码av| 久久精品国内一区二区三区| 91久久精品91久久性色| …久久精品99久久香蕉国产| 国产精品久久久亚洲|