我尝试使用bash转义和双引号方法来逃避下面shell命令中的特殊字符,但两者都没有工作,在ansible playbook中逃避特殊字符的正确方法是什么?
The offending line appears to be:
name: Syncing system date with htpdate failed!, Trying wget method...
shell: date -s "$(curl -s --head http://google.com | grep '^Date:' | sed 's/Date: //g' ) +0530"
^ here
exception type: <class 'yaml.scanner.ScannerError'>
exception: mapping values are not allowed in this context
in "<unicode string>", line 15, column 93
答案 0 :(得分:2)
这里的一个问题是冒号后跟一个空格:
。这通常是映射键的指示符。
YAML不允许在一行上嵌套映射,例如:
foo: bar: baz
这就是为什么YAML设计师选择在映射值中禁止:
,如果它与键位于同一行。 (它可以通过简单地忽略进一步的出现并将其视为常规内容来解决。)
你有几个选择。你可以把整个值放在引号中,这在这种情况下不是一个好主意,因为你有单引号和双引号,那么你就不得不逃避。
解决方法可以是在sed命令中转义空格:
shell: date -s "$(curl -s --head http://google.com | grep '^Date:' | sed 's/Date:\ //g') +0530"
更通用的解决方案是使用折叠块标量:
shell: >
date -s "$(curl -s --head http://google.com | grep '^Date:' | sed 's/Date: //g') +0530"
你甚至可以将它分成几行,因为折叠的块标量会将连续的行折叠为一行:
shell: >
date -s "$(curl -s --head http://google.com
| grep '^Date:' | sed 's/Date: //g') +0530"
第二个问题是,正如Javier所说,sed表达式s/Date/: //g
。你可能想要s/Date: //g
。另请参阅@tripleee关于如何改进命令的建议。
答案 1 :(得分:-1)
考虑逃避特征是\
而不是/
修改强>
您的问题与转义字符无关,这是因为sed
表达式有/
sed 's/Date: ///g'
应该写得像
sed 's/foo/bar/g'
在您的情况下sed 's/Date: //g'