在if条件下,如何使用awk命令中的变量来读取文件的列?
例如,读取下面示例文件的第2列,其中fcolumn1作为2,startdate作为2014-09-22 00:00:00,enddate作为2014-09-23 00:00:00。
abcd,2016-04-23 02:35:34,sdfsdfsd
sdsd,2016-04-22 02:35:34,sdfsdfsd下面的命令起作用:
awk -v startdate="$startdate" -v enddate="$enddate" -F"," '
{
if ($2>=startdate && $2<enddate)
{
print $2
}
}'我们的期望是让$2动态化,如下所示:
awk -v startdate="$startdate" -v enddate="$enddate" -v "fcolumn1=${fcolumn1}" -F"," '
{
if (fcolumn1 != "")
{
if (**$fcolumn1**>=startdate && **$fcloumn1**<enddate)
{
print "$fcolum1"
}
}
}'发布于 2017-10-26 00:11:38
首先,if块是多余的,因为awk程序遵循以下(简化的)结构:
CONDITION { ACTIONS } CONDITION {ACTIONS} ...您可以不使用if语句来编写条件:
awk '$2>=startdate && $2<enddate { print $2 }' file如果您希望通过变量配置实际列数,请注意,您可以使用awk中的变量对列进行寻址,如下所示:
awk -v col=2 '{print $col}'https://stackoverflow.com/questions/46937224
复制相似问题