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:
987-123-4567
123 456 7890
(123) 456-7890
Your script should output the following valid phone numbers:
987-123-4567
(123) 456-7890
Solution
# Read from the file file.txt and output all valid phone numbers to stdout.
egrep -e ^'\([0-9]{3}\) [0-9]{3}-[0-9]{4}'$ -e ^'[0-9]{3}-[0-9]{3}-[0-9]{4}'$ file.txt
Discussion
egrep '^(\d{3}-|\(\d{3}\) )\d{3}-\d{4}$' file.txt
Using sed:
sed -n -r '/^([0-9]{3}-|\([0-9]{3}\) )[0-9]{3}-[0-9]{4}$/p' file.txt
Using awk:
awk '/^([0-9]{3}-|\([0-9]{3}\) )[0-9]{3}-[0-9]{4}$/' file.txt
本文介绍如何使用正则表达式从文本文件中筛选出有效的电话号码。有效电话号码的格式为(xxx)xxx-xxxx 或 xxx-xxx-xxxx。文章提供了egrep、sed及awk三种工具的一行命令解决方案。
1285

被折叠的 条评论
为什么被折叠?



