对于使用 PowerShell 和/或 Perl 的 Windows 计算机,需要与 nmap、awk 和 grep 等效的命令

对于使用 PowerShell 和/或 Perl 的 Windows 计算机,需要与 nmap、awk 和 grep 等效的命令

请参阅此主题以供参考

如何使用 nmap 和 Zenmap 扫描以特定字符串开头的所有主机名?

上述线程中的一个答案使用了以下查询(对于该命令,我完全不承担任何责任):

nmap -sL -oG - 192.168.0.0/24 | awk'$3~/^(org/{print $2}'| nmap -iL -`

它扫描所有节点以以下名称开头的主机名组织并返回匹配节点的列表。

它在 Unix/Linux 环境中运行良好,但我需要一个适用于 Windows 的等效程序。我宁愿不使用适用于 Windows 的 awk、sed 或 grep 包。我想维护一个标准并使用 PowerShell 和/或 Perl。

是否有使用 PowerShell 和/或 Perl 以及 nmap 构建此查询的等效方法?

答案1

该命令的 Nmap 部分应该工作相同。要将awk命令转换为 Perl,请使用:

perl -lane "print $F[1] if $F[2]=~/^\(org/"

(由于 Windows cmd.exe 与大多数 *nix shell 之间的引用差异,*nix shell 应该使用单引号而不是双引号)

要在 PowerShell 中执行相同操作,这应该可行(未经测试):

%{ if ($_.Split()[2] -match "^\(org") { $_.Split()[1]; } }

相关内容