1.题目
给定一个包含电话号码列表(一行一个电话号码)的文本文件 file.txt,写一个单行 bash 脚本输出所有有效的电话号码。
你可以假设一个有效的电话号码必须满足以下两种格式: (xxx) xxx-xxxx 或 xxx-xxx-xxxx。(x 表示一个数字)
你也可以假设每行前后没有多余的空格字符。
示例:
假设 file.txt 内容如下
987-123-4567123 456 7890(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的正则更加多元化,能实现更加复杂的场景。
