如何使用shell脚本变量替换一个文件中的列,并使用awk语句保留列中的双引号

问题描述

文件中的行:

where so.name ="tblname"

shell脚本变量设置为:

for tablename in `cat $TBLNAME.$dbnAM.out`
Shell脚本中的

awk语句:

awk -v xy="$tablename" '$1=="where"{$4='\"xy\"'}1' $COLMNAME > tmp2 && mv tmp2 $COLMNAME

执行awk语句后在输出文件中一行:

where so.name = xy

我想要的是:

where so.name = "tbuser"

解决方法

您必须在其中转义双引号(不使用单引号)。

awk -v xy="$tablename" '$1=="where"{$4="\""xy"\""}1' file

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...