给定一个包含电话号码列表(一行一个电话号码)的文本文件 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
sed -n -r '/^([0-9]{3}-|\([0-9]{3}\) )[0-9]{3}-[0-9]{4}$/p' file.txt
sed一般用来匹配文本并对匹配到的字段进行操作,该题只需要进行匹配
-n 表示只输出匹配的文本
-r表示按照正则表达式进行匹配。
^表示文本的开头 $表示结尾
/ /表示中间的是匹配条件
([0-9]{3}-|\([0-9]{3}\) ) 管道表示满足两者中的一个,[0-9]{3} 表示前三个是0-9的数