此命令按预期工作:
(dpkg -l | egrep "linux.+3.8.0.*44" | awk '{print $2}')
linux-generic-lts-raring
linux-headers-3.8.0-44
linux-headers-3.8.0-44-generic
linux-headers-generic-lts-raring
linux-image-3.8.0-44-generic
linux-image-generic-lts-raring
但是,当我使用bash -c
运行它时,它无法正常工作:
bash -c "(dpkg -l | egrep "linux.+3.8.0.*44" | awk '{print $2}')"
ii linux-generic-lts-raring 3.8.0.44.44 Generic Linux kernel image and headers
ii linux-headers-3.8.0-44 3.8.0-44.66~precise1 Header files related to Linux kernel version 3.8.0
ii linux-headers-3.8.0-44-generic 3.8.0-44.66~precise1 Linux kernel headers for version 3.8.0 on 64 bit x86 SMP
ii linux-headers-generic-lts-raring 3.8.0.44.44 Generic Linux kernel headers
ii linux-image-3.8.0-44-generic 3.8.0-44.66~precise1 Linux kernel image for version 3.8.0 on 64 bit x86 SMP
ii linux-image-generic-lts-raring 3.8.0.44.44 Generic Linux kernel image
我不知道为什么。这几乎就像管道破裂一样。
答案 0 :(得分:4)
因为你是双引号,$2
被shell扩展,而不是字面上传递给awk
。默认情况下,awk中的print
会打印$0
,即。整个输入行,所以如果它被扩展为空值,那就是你的问题。
bash -c "(dpkg -l | egrep 'linux.+3.8.0.*44' | awk '{print \$2}')"
顺便说一下,分别使用grep
和awk
毫无意义。
bash -c "dpkg -l | awk '/linux.+3.8.0.*44/ { print \$2 }'"
如果您的封闭shell本身就是bash,那么可以使用$''
作为提供文字字符串的替代方法:
# $'' only works with bash, ksh, etc., but won't interpret $2, and lets
# you pass literal quotes
bash -c $'dpkg -l | awk \'/linux.+3[.]8[.]0.*44/ { print $2 }\''
相比之下,如果你的封闭shell是基线POSIX,那么在单引号字符串中包含文字单引号会有点复杂。
bash -c 'dpkg -l | awk '"'"'/linux.+3[.]8[.]0.*44/ { print $2 }'"'"''