Tod*_*dge 7 linux string bash duplicates
我有一个重复单词的字符串.我想只显示独特的单词.字符串是:
variable="alpha bravo charlie alpha delta echo charlie"
Run Code Online (Sandbox Code Playgroud)
我知道有几种工具可以一起做到这一点.这就是我想到的:
echo $variable | tr " " "\n" | sort -u | tr "\n" " "
Run Code Online (Sandbox Code Playgroud)
有什么更有效的方法呢?
下面的shell 参数扩展将用换行符替换空格,然后将结果传递给排序实用程序以仅返回唯一的单词。
$ echo -e "${variable// /\\n}" | sort -u
alpha
bravo
charlie
delta
echo
Run Code Online (Sandbox Code Playgroud)
这具有排序单词的副作用,因为sort和uniq实用程序都需要对输入进行排序以检测重复项。如果这不是您想要的,我还发布了一个保留原始词序的Ruby 解决方案。
如果正如一位评论者指出的那样,您试图将您的独特单词重新组合成一行,则可以使用命令替换来执行此操作。例如:
$ echo $(echo -e "${variable// /\\n}" | sort -u)
alpha bravo charlie delta echo
Run Code Online (Sandbox Code Playgroud)
命令替换周围缺少引号是有意的。如果你引用它,换行符将被保留,因为 Bash 不会做word-splitting。不加引号,shell 会将结果作为单行返回,无论这看起来多么不直观。
您可以使用xargs:
echo "$variable" | xargs -n 1 | sort -u | xargs
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5357 次 |
| 最近记录: |