对于shell 对双引号会对$,\,' 进行扩展,而使用单引号则,里面的内容会直接传给awk 作为参数处理。
其中awk,内部有自己的处理原则。输出字符串时使用“”,对于内建变量使用$1等,也可以传进参数 放在末尾。
其中awk 对于 单引号使用特殊,以及转义符。
输出单引号比较麻烦,可以如下使用:
echo 1 | awk '{print "\047" }'
或者
awk '{print "'\''" }'
个人喜好这种,主要是数字太难记了,一段时间肯定忘记!!
对于转义符,使用:
awk '{print "\\" }'
以下是一个例子,实现插入输出的:
有一个文本的内容准备插入到表中,然后打印出来。
#!/bin/bash
# insert value to the table
echo "start"
cat insert.txt | awk '{ print "insert into table (value1,value2,value3)\
values(" "'\''" $1 "'\''&