How can I do ANSI C quoting of an existing bash variable?

喜欢而已 提交于 2019-12-05 13:31:12

By far the simplest solution, if you are using bash:

printf %b "$foo"

Or, to save it in another variable name bar:

printf -v bar %b "$foo"

From help printf:

In addition to the standard format specifications described in printf(1) and printf(3), printf interprets:

 %b        expand backslash escape sequences in the corresponding argument
 %q        quote the argument in a way that can be reused as shell input
 %(fmt)T output the date-time string resulting from using FMT as a format
         string for strftime(3)

There are edge cases, though:

\c terminates output, backslashes in \', \", and \? are not removed, and octal escapes beginning with \0 may contain up to four digits

The best method I know is

  y=$(printf $(echo "$foo"|sed 's/%/%%/g'))

As mentioned in the comments, this trims trailing newlines from $foo. To overcome this:

moo=$(echo "${foo}:end"|sed 's/%/%%/g')
moo=$(printf "$moo")
moo=${moo%:end}
# the escaped string is in $moo
echo "+++${moo}---"

I just found out that I can do this. Edited based on comments.

bar=$( echo -ne "$foo" )

The following works:

 eval bar=\$\'$x\'

The command bar=$'\x61' has to be constructed first, then eval evaluates the newly built command.

Sample of conversion via shell. Problem, the code is octal using \0nnn and hexdecimal (not on all shell) using \xnn (where n are [hexa]digit)

foo="\65"
print "$( echo "$foo" | sed 's/\\/&0/' )"

5

with awk, you could certainly convert it directly

Since bash 4.4 there is a variable expansion to do exactly that:

$ foo='\x61';     echo "$foo" "${foo@E}"
\x61 a

To set another variable use:

$ printf -v bar "${foo@E}";     echo "$bar"
a
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!