sed 字符替换时目标内容包含 & 特殊字符怎么处理

背景

想写一个自动修改配置的脚本,输入一个 mysql jdbc 的连接路径,然后替换目标配置中的模版内容,明明很简单的一个内容,结果卡在了 & 这个符号上。

& 到底是什么特殊字符呢?结论:它代表要替换的旧的字符串。

& 代表什么

在 sed 中 ,& 有特殊含义,但是它不是正则表达式的特殊字符。

脚本接收并替换流程

编写一个脚本 mysql_config.sh ,用来对一个数据库配置文件中的 jdbcUrl 部分进行替换,第一个参数是 URL ,替换过程如下:

bash 复制代码
dbUrl=$2
pathEscaped=$(echo $dbUrl | sed -e 's/\//\\\//g')
pathEscaped=$(echo $pathEscaped | sed -e 's/\&/\\&/g')

originalUrl='jdbc:mysql://IP:port/dbname'
oldEscaped=$(echo $originalUrl | sed -e 's/\//\\\//g')
echo $oldEscaped

sed -i -c "s/$oldEscaped/$pathEscaped/" /myapp/conf/jdbc.properties

脚本注意事项,路径中包含 / 特殊字符,必须转义为 \/ ,第一个转换语句:

bash 复制代码
sed -e 's/\//\\\//g'
sed -e 's/\&/\\&/g')

old 字符串为 /,特殊字符转义为 \/ new 字符串部分是 \/,目标字符串写出转义之后的值就是 \\\/ ,这样才能得到真正要替换的新路径。 & 字符替换为转义后的普通符号 \& ,最终放到目标串中应该是 \\\&

sed -i -c "s/old/new/" 命令执行的时候,如果包含特殊字符,必须都逐个转义,才能得到正确的结果。

相关推荐
付出不多1 小时前
linux——mysql高可用
linux·运维·mysql
C-DHEnry6 小时前
Linux概述:从内核到开源生态
linux
蟑螂恶霸6 小时前
解决ubuntu20中tracker占用过多cpu,引起的风扇狂转
linux·运维·ubuntu
rzsh12346 小时前
[ linux-系统 ] 进程地址空间
linux
1024小神7 小时前
tauri2项目使用sidcar嵌入可执行文件并使用命令行调用
linux·运维·服务器
AI风老师7 小时前
2、ubuntu系统配置OpenSSH | 使用vscode或pycharm远程连接
linux·运维·服务器·ssh
选与握8 小时前
ubuntu工控机固定设备usb串口号
linux·运维·ubuntu
休息一下接着来9 小时前
C++ I/O多路复用
linux·开发语言·c++
舰长1159 小时前
ubuntu 安装mq
linux·运维·ubuntu
liuyunluoxiao9 小时前
进程间通信--信号量【Linux操作系统】
linux