【leetcode】193. 有效电话号码 (简单)

【leetcode】193. 有效电话号码

给定一个包含电话号码列表(一行一个电话号码)的文本文件 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

解题思路:

grep -P 正则匹配

987- [0-9]{3}-
(123) ([0-9]{3})
456-7890 [0-9]{3}-[0-9]{4}

合在一起 ([0-9]{3}-|([0-9]{3}) )[0-9]{3}-[0-9]{4}

代码:

# Read from the file file.txt and output all valid phone numbers to stdout.
grep -P '^([0-9]{3}-|\([0-9]{3}\) )[0-9]{3}-[0-9]{4}$' file.txt

备注:

grep -P 使用 Perl 拓展正则,主要是为了支持\d匹配数字

^匹配开头
$匹配结尾
(、) 括号转义
{3} 匹配出现个数,3表示匹配连续三个数字

你可能感兴趣的:(leetcode,bash,linux)