模式匹配的深入探索与应用
1. 匹配任意字符但排除特定字符
在进行模式匹配时,有时需要匹配除特定字符之外的任意字符。例如,正则表达式模式匹配时, .*\n 虽然能匹配单行,但也会匹配多行,因为多行也以 \n 结尾。若要逐行读取,可使用 ^ 来解决。当 ^ 作为正则表达式范围的第一个字符时,表示匹配除给定字符之外的任意字符,如 [^ ab] 匹配除 a 或 b 之外的任意字符, [^ a - zA - Z] 匹配除字母之外的任意字符。
可以利用范围构建更大的模式,如 [^ ]* 可匹配不包含空格的最长字符串。以下是一个示例代码:
expect -re "([^ ]*) "
该范围匹配每个单词,并将结果存储在 $expect_out(1, string) 中。注意,单词末尾的空格要显式匹配,否则输入缓冲区可能以空格开头,后续匹配会返回空格前的空字符串。
模式匹配会在输入的第一个可能位置匹配最长字符串。若要匹配更后面的内容,可选择更具描述性的模式,或者将 * 替换为 + ,强制模式至少包含一个字母,从而跳过单词间的空格。示例代码如下:
expec
超级会员免费看
订阅专栏 解锁全文
5万+

被折叠的 条评论
为什么被折叠?



