文章

LeetCode Valid Phone Number

Problem

Given a text file file.txt that contains list of phone numbers (one per line), write a one liner bash script to print all valid phone numbers.

You may assume that a valid phone number must appear in one of the following two formats: (xxx) xxx-xxxx or xxx-xxx-xxxx. (x means a digit)

You may also assume each line in the text file must not contain leading or trailing white spaces.

For example, assume that file.txt has the following content:

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

Your script should output the following valid phone numbers:

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

即从文件中找到合法的电话号码。又进入bash题区了。

Bash

1
grep -P '^(\d{3}-|\(\d{3}\) )\d{3}-\d{4}$' file.txt

分析

没啥可说的,正则题而已。唯一需要注意的是,这里用的是\d ,所以需要-P支持。

本文由作者按照 CC BY 4.0 进行授权