bionic (3) regexp.3tcl.gz

Provided by: manpages-zh_1.6.3.2-1_all bug

NAME

       regexp - 针对一个字符串匹配一个正则表达式

总览 SYNOPSIS

       regexp ?switches? exp string ?matchVar? ?subMatchVar subMatchVar ...?
_________________________________________________________________

描述 DESCRIPTION

       确定正则表达式 exp 是否匹配部分或全部 string,在未指定 -inline (参见后面)的时候,如果匹配则返回 1,否则返
       回 0。(正则表达式匹配的描述请参见 re_syntax 参考页。)

       如果在 string 之后指定了补充的参数,则把它们作为变量的名字对待,把关于 string 中匹配 exp 的那部分的信息返
       回到其中。MatchVar 将被设置为匹配全部 expstring 的范围。第一个subMatchVar 将包含与 exp 中最左的圆括号
       中的子表达式相匹配的 string 中那部分字符,下一个 subMatchVar 将包含与exp 中从左到右的下一个圆括号中的子表
       达式相匹配的 string 中那部分字符,以此类推。

       如果给 regexp 的初始的参数以 - 为开始,则它们被作为开关来对待。当前支持下列开关:

       -about         不再尝试匹配正则表达式,返回包含关于正则表达式信息的一个列表。列表的第一个元素是子表达式计
                      数。第二个元素是描述正则表达式各种特性的属性名的一个列表。这个开关主要用于调试目的。

       -expanded      启用展开的(expanded)正则表示式语法,将忽略白空格和注释。这与指定  (?x)  嵌入选项相同。(see
                      METASYNTAX, below).

       -indices       改变在  subMatchVar 中存储的内容。不再存储 string 中匹配的字符串,每个变量将包含两个十进制
                      字符串组成的一个列表,它们给出匹配的字符范围中的第一个和最后一个字符在     string 中的索引
                      。

       -line          启用换行敏感匹配。缺省的,换行是没有特殊意义的一个完全的普通字符。加上了这个标志,‘[^’  方
                      括号表达式和‘.’将永不匹配换行,‘^’除了它的正常功能之外还匹配在任何换行之后的空串,而‘$’除
                      了它的正常功能之外还匹配在任何换行之前的空串。这个标志等价于指定  -linestop-lineanchor
                      二者,或者 (?n) 嵌入选项。 (see METASYNTAX, below).

       -linestop      改变‘[^’方括号表达式和‘.’的行为,这样表示式将停止于换行。这与指定 (?p) 嵌入选项相同。 (see
                      METASYNTAX, below).

       -lineanchor    改变‘^’和‘$’(“锚”)的行为,这样它们分别的匹配一行的开始和结束。这与指定 (?w) 嵌入选项相同。
                      (see METASYNTAX, below).

       -nocase        导致在匹配处理中把 string 中的大写字符与小写字符同样对待。                                 │

       -all                                                                                                      │
                      导致尽字符串中可能的次数去匹配正则表达式,返回发现的匹配总数。如果一起指定的还有匹配变     │
                      量,它们将只保持最后的匹配。                                                               │

       -inline                                                                                                   │
                      导致命令把原先要放置到匹配变量中的数据作为一个列表返回。当使用  -inline 的时候,不可以指定 │
                      匹配变量。如果还使用了 -all,在每次重复操作(iteration)时串联列表,这样将总是返回一个平坦的 │
                      列表。对于每次匹配的重复操作,这个命令将添加整体的匹配数据,为正则表达式中的每个子表达式加 │
                      上一个元素。例如:                                                                          │
                          regexp -inline -- {\w(\w)} " inlined "                                                 │
                       => {in n}                                                                                 │
                          regexp -all -inline -- {\w(\w)} " inlined "                                            │
                       => {in n li i ne e}                                                                       │

       -start index                                                                                              │
                      在字符串中指定一个字符索引,在这个偏移量上开始匹配。当使用了这个开关的时候,‘^’将不匹配行  │
                      的开始,而      0index 上匹配字符串的开始。如果指定了 -indices,编制索引将以输入字符串的绝 │
                      对开始为起始。index     将被约束为输入字符串的束缚。

       --             标记开关的结束。这个标志之后的参数即使以 - 为开始仍被作为 exp 对待。

       如果 subMatchVarexp 中的圆括号中的子表达式多,或者在 exp  中的一个特定子表达式不匹配字符串。(比如,因
       为它是不被匹配的子表达式的一部分),  则在指定了 -indices 的时候,相应subMatchVar 将被设置成``-1 -1'',其他
       时候被设置成空串。

参见 SEE ALSO

       re_syntax(n), regsub(n)

关键字 KEYWORDS

       match, regular expression, string

[中文版维护人]

       寒蝉退士

[中文版最新更新]

       2001/10/27

《中国 Linux 论坛 man 手册页翻译计划》:

       http://cmpp.linuxforum.net

       本页面中文版由中文 man 手册页计划提供。
       中文 man 手册页计划:https://github.com/man-pages-zh/manpages-zh