1.题目

给定一个包含电话号码列表(一行一个电话号码)的文本文件 file.txt,写一个单行 bash 脚本输出所有有效的电话号码。

你可以假设一个有效的电话号码必须满足以下两种格式: (xxx) xxx-xxxx 或 xxx-xxx-xxxx。(x 表示一个数字)

你也可以假设每行前后没有多余的空格字符。

示例:

假设 file.txt 内容如下

  1. 987-123-4567
  2. 123 456 7890
  3. (123) 456-7890

你的脚本应当输出下列有效的电话号码:

987-123-4567
(123) 456-7890

2.思路

还是第一次知道leetcode有这种题,这种判断电话号是否合规我们一般选择用正则表达式来判断:

表达xxx-xxx-xxxx的正则:

^[0-9]{3}-[0-9]{3}-[0-9]{4}$

表达(xxx) xxx-xxxx的正则:

^\([0-9]{3}\) [0-9]{3}-[0-9]{4}$

然后我们发现,后面的正则是一样的,所以合并为:

^([0-9]{3}-|\([0-9]{3}\) )[0-9]{3}-[0-9]{4}$

然后我们利用linux的grep命令来操作

grep -P '^([0-9]{3}-|\([0-9]{3}\) )[0-9]{3}-[0-9]{4}$' file.txt

关于grep -P命令:

Interpret PATTERN as a Perl regular expression. This is highly experimental and grep -P may warn of nimplemented features.

这意思是,-P 可以让grep使用perl的正则表达式语法,因为perl的正则更加多元化,能实现更加复杂的场景。