如何在 linux shell 中使用正则表达式从文件中提取 IP 地址?

新手上路,请多包涵

如何在 linux shell 中通过正则表达式提取文本部分?可以说,我有一个文件,其中每一行都有一个 IP 地址,但位置不同。使用常见的 unix 命令行工具提取这些 IP 地址的最简单方法是什么?

原文由 Kazimieras Aliulis 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 1.7k
2 个回答

您可以使用 grep 将它们拉出。

 grep -o '[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}' file.txt

原文由 brien 发布,翻译遵循 CC BY-SA 2.5 许可协议

此处的大多数示例将匹配 999.999.999.999,这在技术上不是有效的 IP 地址。

以下将仅匹配有效的 IP 地址(包括网络和广播地址)。

 grep -E -o '(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)' file.txt

如果要查看匹配的整行,请省略 -o。

原文由 Sarel Botha 发布,翻译遵循 CC BY-SA 3.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题