我的Linux上有一个file.txt,它的结构如下所示:
file.txt:
full name
E-mail: email@email.com
Phone: 0123456789
full name
email@email.com
01/23456789
full name
e: email@email.com
00-223-445-56
.
.
.
etc或只提供姓名、入口及电话号码或电子邮件地址。
我想在我开始的时候使用grep
./myprogram.sh file.txt列出文件中的所有电子邮件地址和电话号码。如果file.txt是这样的,我该怎么做呢?
发布于 2016-11-26 22:48:05
你可以从这样简单的事情开始:
cat file.txt | grep -E "(@|[0-9]+)"它给你所有的东西都有@(所以是电子邮件)和所有有号码的东西(所以是电话号码)。您可以使用更高级的正则表达式进行更好的搜索(电子邮件和电话号码确实有更严格的规则.)但这就是我的想法。
发布于 2016-11-26 22:57:28
egrep "@|[0-9]"将只匹配包含"@“或至少一位数的行。您的示例说明名称行不包含数字。
发布于 2016-11-27 04:27:14
目前还不清楚您期望哪种格式作为输出。如果你想把电子邮件地址和电话号码分开(这就是你想要的吗?)连接:电子邮件地址<->电话号码会有点混乱)您也可以使用(GNU) sed:
sed -n -e '1 {s/\(.*\)/e-mail:\n\1/; P;};' \
-e '/@/ s/\(.\+[ \\\t]\)\{0,1\}\(.\+\)@\(.\+\)/\t\2\@\3/p;' \
-e '/[0-9]\+$/ H; $ {x; s/\n\([^0-9]*\)\([0-9]\+\)/\n\t\2/g; s/\(.*\)/\nphone:\n\1/p;}'
file.txthttps://stackoverflow.com/questions/40823857
复制相似问题