对于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 "'\''" ",'\''" $2 "'\''" ",'\''" $3 "'\'')" }'
echo "end"
结果如下:
start
insert into table (value1,value2,value3) values('1','2','3')
insert into table (value1,value2,value3) values('4','5','6')
insert into table (value1,value2,value3) values('7','8','9')
end


发布评论