在我的stats.txt
页面中,我有以下内容:
Get-VMHardDiskDrive | Select-Object Path
ComputerName : ACD-VMH04
Path : D:\HYPER-V\VMDEV01\Virtual Hard Disks\f9314d7d-5d2d-11e0-8feb-806e6f6e6963_2012-06-29T153327.vhd
VhdFormat : VHD
VhdType : Dynamic
Used Space : .07
Prov Space : 4.00
ComputerName : ACD-VMH04
Path : D:\HYPER-V\VMDEV01\Virtual Hard Disks\C_2012-06-29T153327.vhd
VhdFormat : VHD
VhdType : Dynamic
Used Space : 258.04
Prov Space : 906.34
我运行以下AWK
命令来给我这个:
ACD-VMH04
D:\HYPER-V\VMDEV01\Virtual Hard Disks\f9314d7d-5d2d-11e0-8feb-806e6f6e6963_2012-06-29T153327.vhd
VHD
Dynamic
.07
4.00
ACD-VMH04
D:\HYPER-V\VMDEV01\Virtual Hard Disks\C_2012-06-29T153327.vhd
VHD
Dynamic
258.04
906.34
该文件大约有 6 个类似的项目,但是其他文件有更多,所以我想知道如何让输出看起来像这样:
ACD-VMH04 - D:\HYPER-V\VMDEV01\Virtual Hard Disks\f9314d7d-5d2d-11e0-8feb-806e6f6e6963_2012-06-29T153327.vhd - VHD - Dynamic - .07 - 4.00
ACD-VMH04 - D:\HYPER-V\VMDEV01\Virtual Hard Disks\C_2012-06-29T153327.vhd - VHD - Dynamic - 258.04 - 906.34
这在某种程度上可以完成这项工作,但是我不知道如何告诉它停止并在遇到空行时换行。
awk -F " : " '{ ORS = " " } /Select-Object Path/ { output = 1; start = NR + 2 }; output && NR >= start { print $2, "-" }' stats.txt
答案1
我没有适合您的一行,但这里的关键概念是存储该字段,直到您收集完所有内容,然后将它们打印在一行上。此外,空行的字段数 (NF) 为零。
代码:
#!/bin/awk -f
BEGIN {FS = " : "; OFS = " - "}
NF > 0 {
gsub(/[ ]+$/, "", $1)
a[$1] = $2
}
NF == 0 {dump()}
END {dump()}
function dump() {
print a["ComputerName"], a["Path"], a["VhdFormat"], a["VhdType"]
}
结果:
ACD-VMH04 - D:\HYPER-V\VMDEV01\Virtual Hard Disks\f9314d7d-5d2d-11e0-8feb-806e6f6e6963_2012-06-29T153327.vhd - VHD - Dynamic
ACD-VMH04 - D:\HYPER-V\VMDEV01\Virtual Hard Disks\C_2012-06-29T153327.vhd - VHD - Dynamic
答案2
perl -lne '
/Select-Object Path/ and !$a++ and <>,next;
/^ComputerName\s+:/ && $a .. /^$/ || eof and do{
push @A, (/\s+:\s+\K(.*)/)[0] if /^ComputerName\s+:/ || /./;
print join(" - ", splice(@A,0,@A)),"\n" if /^$/ || eof;
};
' stats.txt
输出
ACD-VMH04 - D:\HYPER-V\VMDEV01\Virtual Hard Disks\f9314d7d-5d2d-11e0-8feb-806e6f6e6963_2012-06-29T153327.vhd - VHD - Dynamic - .07 - 4.00
ACD-VMH05 - D:\HYPER-V\VMDEV01\Virtual Hard Disks\C_2012-06-29T153327.vhd - VHD - Dynamic - 258.04 - 906.34
答案3
我们可以使用“:”作为分隔符并打印 awk 中每行的第二个字段
awk -v FS=" : " -v ORS="" '{{print $2,"- "}; if ( $0 ~ /^$/) {print "\n"}}' stats.txt