linux-提取域,然后使用sed / awk / grep / perl粘贴到同一行
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了linux-提取域,然后使用sed / awk / grep / perl粘贴到同一行,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1177字,纯文字阅读大概需要2分钟。
内容图文
![linux-提取域,然后使用sed / awk / grep / perl粘贴到同一行](/upload/InfoBanner/zyjiaocheng/947/350e545cde7a4545aa1384da0c291a66.jpg)
不久之前,我就开始了我的技术冒险-就像您从问题中感到的那样-但现在我陷入了困境,因为经过将近一整天的思考和搜索,我不知道解决我问题的合适方法.
简而言之,我得到了一个包含数千行的文件,其中包含电子邮件和名字.问题是我真的需要在域名旁边添加另一列,例如电子邮件地址旁边的域名.请看下面的例子.
现在是这样的:
something@nothing.tld|:|george|-| anything@another.tld|:|thomas|-| third@address.tld|:|kelly|-|
我想要的样子:
something@nothing.tld|:|nothing.tld|--|george|-| anything@another.tld|:|another.tld|--|thomas|-| third@address.tld|:|address.tld|--|kelly|-|
我最好的猜测是使用sed开始该过程并提取域,但是如何将提取的域粘贴到粘贴的同一行中.
sed -e 's/.*@\(.*\)|:|*/\1/'
如果您还可以给出简短的解释以及解决方案,那将非常有帮助.
任何帮助表示赞赏.
解决方法:
如果您在名为file1的文件中包含以下数据,
something@nothing.tld|:|george|-|
anything@another.tld|:|thomas|-|
third@address.tld|:|kelly|-|
您可以使用:和@作为分隔符,并使用awk在其后添加数据,然后将其保存到新文件中,
awk -F '[@:]' '{ print $1"@"$2 ":|" $2"--" $3 }' file1 > file2
上面的命令将以下数据保存在名为file2的文件中,
something@nothing.tld|:|nothing.tld|--|george|-|
anything@another.tld|:|another.tld|--|thomas|-|
third@address.tld|:|address.tld|--|kelly|-|
内容总结
以上是互联网集市为您收集整理的linux-提取域,然后使用sed / awk / grep / perl粘贴到同一行全部内容,希望文章能够帮你解决linux-提取域,然后使用sed / awk / grep / perl粘贴到同一行所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。