我正在努力使sed工作来应用替代操作以下波纹管。PHP的preg_quote等价于Bash?
SALT=$(curl -L https://api.wordpress.org/secret-key/1.1/salt/)
#SALT='test' #this of course works fine
#echo $SALT
sed -i "s/salt_here/$SALT/g" wp-config.php
在文件“wp-config.php”中有一行字“salt_here”(不含引号)。然而,$ SALT变量有很多垃圾,所以我得到这个错误:
sed: -e expression #1, char 78: unknown option to `s'
有没有办法逃避一个变量(就像PHP的http://php.net/preg_quote)
UPDATE内所有的垃圾:
这是最好的,我可以得到:
SALT=$(curl -L https://api.wordpress.org/secret-key/1.1/salt/ | sed 's/\(\/\|\\\|&\)/\\&/g')
SALT1=`/usr/bin/php << EOF
<?php echo preg_quote("$SALT"); ?>
EOF`
#echo "$SALT1"
cp '/home/public_html/zz_f/wp-config.php' '/home/public_html/zz_f/wp-config_t.php'
sed -i "s/salt_here/$SALT1/g" wp-config.php
但还是有一个错误:
PHP Parse error: syntax error, unexpected '>', expecting T_VARIABLE or '$' in - on line 3
sed: -e expression #1, char 12: unterminated `s' command
这不可能与单引号围绕sed表达式。 Bash不会取代$ SALT的价值。 – 2011-06-03 19:43:01
也许这有助于:http://stackoverflow.com/questions/407523/bash-escape-a-string-for-sed-search-pattern – hakre 2011-06-03 19:46:48
我的错误:它现在在双引号内。 – Roger 2011-06-03 20:04:44