题目描述
- 给定一个包含电话号码列表(一行一个电话号码)的文本文件 file.txt,写一个单行 bash 脚本输出所有有效的电话号码。
- 你可以假设一个有效的电话号码必须满足以下两种格式: (xxx) xxx-xxxx 或 xxx-xxx-xxxx。(x 表示一个数字)
- 你也可以假设每行前后没有多余的空格字符。
示例
- 假设 file.txt 内容如下:
987-123-4567
123 456 7890
(123) 456-7890
- 你的脚本应当输出下列有效的电话号码:
987-123-4567
(123) 456-7890
题解1
sed -n -r '/^([0-9]{3}-|\([0-9]{3}\) )[0-9]{3}-[0-9]{4}$/p' file.txt
| 或者
参数解释:
-n | 静默输出 |
---|---|
-r | 启用扩展的正则表达式 |
/ | 分隔符 |
^ | 匹配以指定字符开头的 |
$ | 匹配以指定字符结尾的 |
[0-9] | 数字0到9 |
{3} | 表示字符长度为3 |
\ | 转义 |
竖线 | 表示或者 |
/p | 查看 |
题解2
grep -o -w -E "^[(][0-9]{3}[)] [0-9]{3}-[0-9]{4}$|^[0-9]{3}-[0-9]{3}-[0-9]{4}$" file.txt
参数解释:
-o | (暂时没找到) |
---|---|
-w(–word-regexp ) | 只显示全字符合的列 |
-E(–extended-regexp) | 将范本样式为延伸的普通表示法来使用 |