有效电话号码-leetcode
有效电话号码
- 1. 地址
- 2. 解法
shell 编程题目
考察了很多方面的内容
- shell 命令 grep | sed | awk
- 正则表达式
- shell 的转义处理
1. 地址
https://leetcode-cn.com/problems/valid-phone-numbers/
2. 解法
你可以假设一个有效的电话号码必须满足以下两种格式: (xxx) xxx-xxxx 或 xxx-xxx-xxxx。(x 表示一个数字)
分析题目,发现两种格式有一个共同的部分,可以表示成
\d{3}-\d{4}$
不同的部分可以表示成
$\(\d{3}\)\s
或者
$\d{3}-
解释:
\d
代表匹配数字,{3} 代表匹配多少次数字\s
表示空白字符
grep -P "^(\(\d{3}\)\s|\d{3}-)(\d{3}-)\d{4}$" file.txt
这里要注意,在 linux
的 shell
中普通的 grep
或者 egrep
是不支持 \d
这种缩略形式的,必须使用 [0-9]
代表数字
如果需要使用 \d
那么必须指定 -P
选项,代表指定 perl
形式的正则表达式,这个需要读者自行查阅资料看一下不同标准的正则的异同点。
?