admin 管理员组

文章数量: 1184232

对于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


本文标签: 其中 系统 编程