Linux bash命令返回两个字符串不同的地方

所以,我一直在谷歌搜索,并在堆栈溢出中搜索更多细节,但我似乎无法找到一个简单的方法来做到这一点:

我想知道两个字符串(没有空格)有什么不同,并简单地打印出确切的差异.

例如.:

Input 1 > "Chocolatecakeflavour"
Input 2 > "Chocolateflavour"

Output: "cake"

我已经尝试使用diff和dwdiff,cmp以及其他已知的bash命令,但是我无法得到这个确切的结果.

有任何想法吗?

解决方法:

您可以使用带折叠的diff和像这样的awk:

s="Chocolatecakeflavour"
r="Chocolateflavour"

diff <(fold -w1 <<< "$s") <(fold -w1 <<< "$r") | awk '/[<>]/{printf $2}'
cake

> fold -w1是逐字符分割输入字符串(每行一个)
> diff是两个列表中的差异(每行1个字符)
> awk’/ [<>] / {printf $2}’将抑制<或者>来自diff'e输出并打印同一行中的所有内容
编辑:根据OP的评论,如果字符串在文件的不同行中,则使用:

f=file
diff <(fold -w1 <(sed '2q;d' $f)) <(fold -w1 <(sed '3q;d' $f)) | awk '/[<>]/{printf $2}'
cake

相关文章

用的openwrt路由器,家里宽带申请了动态公网ip,为了方便把2...
#!/bin/bashcommand1&command2&wait从Shell脚本并行...
1.先查出MAMP下面集成的PHP版本cd/Applications/MAMP/bin/ph...
1、先输入locale-a,查看一下现在已安装的语言2、若不存在如...
BashPerlTclsyntaxdiff1.进制数表示Languagebinaryoctalhexa...
正常安装了k8s后,使用kubect工具后接的命令不能直接tab补全...