返回两个字符串不同之处的 Linux bash 命令

标签 linux string bash command-line difference

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

我想知道两个字符串(没有空格)有何不同,并简单地打印出确切的区别是什么。

例如:

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

Output: "cake"

我已经尝试使用 diff 和 dwdiff、cmp 以及突然想到的其他已知 bash 命令来执行此操作,但我就是无法得到这个确切的结果。

有什么想法吗?

最佳答案

您可以使用 difffoldawk像这样:

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

关于返回两个字符串不同之处的 Linux bash 命令,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26525290/

相关文章:

linux - Debian - 找不到 add-apt-repository,找不到 software-properties-common

linux - LD_PRELOAD 不适用于 printf

linux - 从 ubuntu 客户端远程访问 debian 服务器

c++ - 将字符 vector 转换为字符串的最快方法

c - 打印两个字符串

c++ - 计算文件中的偶数行数

bash - 在 bash 中模拟 ENTER 键here-document

php - UTF-8贯穿始终

bash:将脚本的输出作为脚本执行

linux - Bash从文件列表中获取时间戳并将其与文件名进行比较