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

时间:2014-10-23 09:39:51

标签: linux string bash command-line difference

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

我想知道两个字符串(没有空格)的不同之处,只是打印出确切的区别。

E.g:

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

Output: "cake"

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

有什么想法吗?

1 个答案:

答案 0 :(得分:5)

您可以将difffoldawk一起使用:

s="Chocolatecakeflavour"
r="Chocolateflavour"

diff <(fold -w1 <<< "$s") <(fold -w1 <<< "$r") | awk '/[<>]/{printf $2}'
cake
  • fold -w1是逐字符分割输入字符串(每行一个)
  • diff将在两个列表中获得差异(每行1个字符)
  • awk '/[<>]/{printf $2}'是禁止< OR >从差异输出并打印所有内容

编辑:根据OP的评论,如果字符串位于文件的不同行,请使用:

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