在bash上反转uniq命令
我正在尝试查找特定电子邮件ID重复的次数。管道在bash上反转uniq命令,bash,unix,awk,sed,grep,Bash,Unix,Awk,Sed,Grep,我正在尝试查找特定电子邮件ID重复的次数。管道uniq-c与我得到的输出420 aol.com但是我需要aol.com 420如何做,因为uniq-c作为前缀计数应用您可以将输出管道到awk: string='420 aol.com' echo "$string" | awk '{print $2,$1}' aol.com 420 默认情况下,awk用空格分隔每个字段 420是第一个字段$1 aol.com是第二个字段$2 这只是告诉awk以相反的顺序打印这些字段{print$2,$1}
uniq-c
与我得到的输出420 aol.com
但是我需要aol.com 420
如何做,因为uniq-c
作为前缀计数应用您可以将输出管道到awk
:
string='420 aol.com'
echo "$string" | awk '{print $2,$1}'
aol.com 420
默认情况下,awk
用空格分隔每个字段
是第一个字段420
$1
是第二个字段aol.com
$2
这只是告诉
awk
以相反的顺序打印这些字段{print$2,$1}
您可以通过管道将输出传输到awk
:
string='420 aol.com'
echo "$string" | awk '{print $2,$1}'
aol.com 420
默认情况下,awk
用空格分隔每个字段
是第一个字段420
$1
是第二个字段aol.com
$2
这只是告诉
awk
以相反的顺序打印这些字段{print$2,$1}
如果您有电子邮件地址列表,例如:
$ cat emails.txt
1@aol.com
2@yahoo.com
3@aol.com
您需要使用awk计算他们的域数:
$ awk -F@ '{a[$2]++} END {for(i in a) print i, a[i]}' emails.txt
aol.com 2
yahoo.com 1
这些记录不按特定顺序输出。如果使用Gnu awk,可以使用
PROCINFO[“sorted_in”]=“val_num_asc”对记录进行排序在开始
块开头的code>(请参阅选项之一)。如果您有电子邮件地址列表,例如:
$ cat emails.txt
1@aol.com
2@yahoo.com
3@aol.com
您需要使用awk计算他们的域数:
$ awk -F@ '{a[$2]++} END {for(i in a) print i, a[i]}' emails.txt
aol.com 2
yahoo.com 1
这些记录不按特定顺序输出。如果使用Gnu awk,可以使用PROCINFO[“sorted_in”]=“val_num_asc”对记录进行排序代码>(请参阅选项的)在开始
块的开头。添加带有电子邮件和预期输出的示例输入。。。你的问题本身没有足够的细节来提出解决方案。。另请参见@Sundeep,输入为abc123@aol.com和当前输出:1 aol.com;意味着发现1封aol.com电子邮件;我需要的输出是:aol.com 1oh好的,这很容易做到,而且你已经得到了答案:)请参阅添加带有电子邮件和预期输出的示例输入。。。你的问题本身没有足够的细节来提出解决方案。。另请参见@Sundeep,输入为abc123@aol.com和当前输出:1 aol.com;意味着发现1封aol.com电子邮件;我需要的输出是:aol.com 1oh好的,这很容易做到,而且你已经得到了答案:)看,这是否有效,即使它是一个列表420 aol.com 123 yahoo.com 11 gmail.com这会给aol.com 420 yahoo.com 123 gmail.com 11肯定会的。uniq
的输出将在新行中显示每个结果集awk
只需交换此输出的1st
和2nd
列。即使它是一个列表420 aol.com 123 yahoo.com 11 gmail.com,也可以工作吗。uniq
的输出将在新行中显示每个结果集awk
只需交换此输出的1st
和2nd
列。