首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >sed命令,用于查找带有特殊字符的字符串并将其替换为命令行中的字符串

sed命令,用于查找带有特殊字符的字符串并将其替换为命令行中的字符串
EN

Stack Overflow用户
提问于 2020-05-11 06:44:37
回答 2查看 200关注 0票数 0

我正在尝试使用sed在.property文件中查找/替换具有特殊字符的字符串。

这是我在文件中的原始行:

代码语言:javascript
复制
kylin.source.hive.beeline-params=-n root --hiveconf hive.security.authorization.sqlstd.confwhitelist.append='mapreduce.job.*|dfs.*' -u jdbc:hive2://localhost:xxxx

我需要替换:

代码语言:javascript
复制
root --hiveconf hive.security.authorization.sqlstd.confwhitelist.append='mapreduce.job.*|dfs.*'

使用

代码语言:javascript
复制
hadoop

和其他字符串:

代码语言:javascript
复制
localhost

使用

代码语言:javascript
复制
ip-00-00-00-000.ec2.internal

最终输出需要如下所示:

代码语言:javascript
复制
kylin.source.hive.beeline-params=-n hadoop -u jdbc:hive2://ip-00-00-00-000.ec2.internal:xxxx

我使用sed尝试了几种不同的格式:

代码语言:javascript
复制
sudo sed -i 's/root --hiveconf hive\.security\.authorization\.sqlstd\.confwhitelist\.append=\'mapreduce\.job\.\*\|dfs\.\*\'/hadoop' /usr/local/kylin/kylin.properties
代码语言:javascript
复制
sudo sed -i 's/root \-\-hiveconf hive\.security\.authorization\.sqlstd\.confwhitelist\.append\=\'mapreduce\.job\.\*\|dfs\.\*\'/hadoop' /usr/local/kylin/kylin.properties
代码语言:javascript
复制
sudo sed -r 's/root \-\-hiveconf hive\.security\.authorization\.sqlstd\.confwhitelist\.append\=\'mapreduce\.job\.\*\|dfs\.\*\'/hadoop' /usr/local/kylin/kylin.properties

当我执行上面的命令时,我没有得到任何输出,它正在等待另一个input.Can有人帮助我解决这个问题吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-05-11 07:40:29

这里:

代码语言:javascript
复制
sed -i "s#root.*dfs.*'#hadoop#g; s#localhost#ip-00-00-00-000.ec2.internal#g" /usr/local/kylin/kylin.properties

将输出:

代码语言:javascript
复制
kylin.source.hive.beeline-params=-n hadoop -u jdbc:hive2://ip-00-00-00-000.ec2.internal:xxxx

或者仅替换文件中的第一个匹配项:

代码语言:javascript
复制
sed -i "0,/root.*dfs/{s#root.*dfs.*'#hadoop#g; s#localhost#ip-00-00-00-000.ec2.internal#g}" /usr/local/kylin/kylin.properties
票数 0
EN

Stack Overflow用户

发布于 2020-05-11 21:15:17

当您想要用文字字符串替换文字字符串时,可以使用awk这样的工具来理解文字字符串,而不是使用像sed这样的工具来理解regexp和启用了反向引用的替换,然后您需要以不同的方式小心地转义它们的元字符和分隔符(请参见is-it-possible-to-escape-regex-metacharacters-reliably-with-sed

代码语言:javascript
复制
$ cat tst.awk
BEGIN {
    map["root --hiveconf hive.security.authorization.sqlstd.confwhitelist.append='mapreduce.job.*|dfs.*'"] = "hadoop"
    map["localhost"] = "ip-00-00-00-000.ec2.internal"
}
{
    for (str in map) {
        if ( s = index($0,str) ) {
            $0 = substr($0,1,s-1) map[str] substr($0,s+length(str))
        }
    }
    print
}

$ awk -f tst.awk file
kylin.source.hive.beeline-params=-n hadoop -u jdbc:hive2://ip-00-00-00-000.ec2.internal:xxxx
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61719693

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档