我如何逃脱双引号内的双字符串在Bash?

例如,在我的shell脚本中

#!/bin/bash

dbload="load data local infile \"'gfpoint.csv'\" into table $dbtable FIELDS TERMINATED BY ',' ENCLOSED BY '\"' LINES TERMINATED BY \"'\n'\" IGNORE 1 LINES"

我不能得到由'\"'与双引号括起来正确转义。我的变量不能使用单引号,因为我想使用变量$dbtable。


当前回答

检查printf…

#!/bin/bash
mystr="say \"hi\""

不使用printf

echo -e $mystr

输出:说“hi”

使用printf

echo -e $(printf '%q' $mystr)

输出:say“hi”

其他回答

使用反斜杠:

echo "\""     # Prints one " character.

检查printf…

#!/bin/bash
mystr="say \"hi\""

不使用printf

echo -e $mystr

输出:说“hi”

使用printf

echo -e $(printf '%q' $mystr)

输出:say“hi”

一个在shell中转义引号的简单例子:

$ echo 'abc'\''abc'
abc'abc
$ echo "abc"\""abc"
abc"abc

它是通过完成一个已经打开的('),放置转义的(\'),然后打开另一个(')来完成的。

另外:

$ echo 'abc'"'"'abc'
abc'abc
$ echo "abc"'"'"abc"
abc"abc

它是通过结束已经打开的一个('),在另一个引号(“'”)中放置一个引号,然后打开另一个(')来完成的。

更多示例:在单引号字符串中转义单引号

在双引号前添加“\”来转义,而不是\

#! /bin/csh -f

set dbtable = balabala

set dbload = "load data local infile "\""'gfpoint.csv'"\"" into table $dbtable FIELDS TERMINATED BY ',' ENCLOSED BY '"\""' LINES TERMINATED BY "\""'\n'"\"" IGNORE 1 LINES"

echo $dbload
# load data local infile "'gfpoint.csv'" into table balabala FIELDS TERMINATED BY ',' ENCLOSED BY '"' LINES TERMINATED BY "''" IGNORE 1 LINES

将双引号字符存储在变量中:

dqt='"'
echo "Double quotes ${dqt}X${dqt} inside a double quoted string"

输出:

Double quotes "X" inside a double quoted string