Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/bash/17.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
计算bash中每行只有一个字符串的唯一字符串_Bash_Count - Fatal编程技术网

计算bash中每行只有一个字符串的唯一字符串

计算bash中每行只有一个字符串的唯一字符串,bash,count,Bash,Count,给定输入文件 z b a f g a b ... 我想输出每个字符串的出现次数,例如: z 1 b 2 a 2 f 1 g 1 如何在bash脚本中完成此操作?您可以将输入和传递到: 如果要将数字显示在右侧,请使用切换: $ sort input_file | uniq -c | awk '{print $2, $1}' a 2 b 2 f 1 g 1 z 1 或者,在awk中完成整个过程: 您可以将输入和传递到: 如果要将数字显示在右侧,请使用切换: $ sort input_file

给定输入文件

z
b
a
f
g
a
b
...
我想输出每个字符串的出现次数,例如:

z 1
b 2
a 2
f 1
g 1
如何在bash脚本中完成此操作?

您可以将输入和传递到:

如果要将数字显示在右侧,请使用切换:

$ sort input_file | uniq -c | awk '{print $2, $1}'
a 2
b 2
f 1
g 1
z 1
或者,在awk中完成整个过程:

您可以将输入和传递到:

如果要将数字显示在右侧,请使用切换:

$ sort input_file | uniq -c | awk '{print $2, $1}'
a 2
b 2
f 1
g 1
z 1
或者,在awk中完成整个过程:

我应该做这项工作

应该执行此任务

您可以使用排序文件名| uniq-c

看看。

您可以使用排序文件名| uniq-c

看看。

试试:

awk '{ freq[$1]++; } END{ for( c in freq ) { print c, freq[c] } }' test.txt
其中test.txt将是您的输入文件。

请尝试:

awk '{ freq[$1]++; } END{ for( c in freq ) { print c, freq[c] } }' test.txt
其中test.txt将是您的输入文件。

这里有一个仅适用于bash的版本,它需要使用bash版本4

这里有一个仅限于bash的版本,它需要bash版本4,使用


这可能适合您:

cat -n file | 
sort -k2,2 | 
uniq -cf1 | 
sort -k2,2n | 
sed 's/^ *\([^ ]*\).*\t\(.*\)/\2 \1/'

这将输出每个字符串按其出现顺序出现的次数。

这可能适用于您:

cat -n file | 
sort -k2,2 | 
uniq -cf1 | 
sort -k2,2n | 
sed 's/^ *\([^ ]*\).*\t\(.*\)/\2 \1/'

这将按每个字符串的出现顺序输出它们的出现次数。

需要bash版本4才能获得关联数组simpler:count[$val]++。此外,您几乎应该始终在read中使用-r。始终引用变量:${!count[@]}和echo$key${count[$key]}中的键。关联数组需要bash版本4更简单:count[$val]++。此外,您几乎应该始终在read中使用-r。始终引用变量:${!count[@]}和echo$key${count[$key]}中的键。
cat -n file | 
sort -k2,2 | 
uniq -cf1 | 
sort -k2,2n | 
sed 's/^ *\([^ ]*\).*\t\(.*\)/\2 \1/'