为什么这个过程没有结束?

为什么这个过程没有结束?
 wc -l | sort -t":" -k4,4n | uniq password_demo.txt

印刷

root:x:0:0:root:/root:/bin/bash
daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin
bin:x:2:2:bin:/bin:/usr/sbin/nologin
sys:x:3:3:sys:/dev:/usr/sbin/nologin
sync:x:4:65534:sync:/bin:/bin/sync
games:x:5:60:games:/usr/games:/usr/sbin/nologin
man:x:6:12:man:/var/cache/man:/usr/sbin/nologin
lp:x:7:7:lp:/var/spool/lpd:/usr/sbin/nologin
mail:x:8:8:mail:/var/mail:/usr/sbin/nologin
news:x:9:9:news:/var/spool/news:/usr/sbin/nologin
uucp:x:10:10:uucp:/var/spool/uucp:/usr/sbin/nologin
proxy:x:13:13:proxy:/bin:/usr/sbin/nologin
www-data:x:33:33:www-data:/var/www:/usr/sbin/nologin
backup:x:34:34:backup:/var/backups:/usr/sbin/nologin
list:x:38:38:Mailing List Manager:/var/list:/usr/sbin/nologin
irc:x:39:39:ircd:/var/run/ircd:/usr/sbin/nologin
gnats:x:41:41:Gnats Bug-Reporting System (admin):/var/lib/gnats:/usr/sbin/nologin
nobody:x:65534:65534:nobody:/nonexistent:/usr/sbin/nologin
systemd-timesync:x:100:102:systemd Time Synchronization,,,:/run/systemd:/bin/false
systemd-network:x:101:103:systemd Network Management,,,:/run/systemd/netif:/bin/false
systemd-resolve:x:102:104:systemd Resolver,,,:/run/systemd/resolve:/bin/false
systemd-bus-proxy:x:103:105:systemd Bus Proxy,,,:/run/systemd:/bin/false
syslog:x:104:108::/home/syslog:/bin/false
_apt:x:105:65534::/nonexistent:/bin/false
messagebus:x:106:110::/var/run/dbus:/bin/false
uuidd:x:107:111::/run/uuidd:/bin/false
lightdm:x:108:114:Light Display Manager:/var/lib/lightdm:/bin/false
whoopsie:x:109:117::/nonexistent:/bin/false
avahi-autoipd:x:110:119:Avahi autoip daemon,,,:/var/lib/avahi-autoipd:/bin/false
avahi:x:111:120:Avahi mDNS daemon,,,:/var/run/avahi-daemon:/bin/false
colord:x:112:123:colord colour management daemon,,,:/var/lib/colord:/bin/false
dnsmasq:x:113:65534:dnsmasq,,,:/var/lib/misc:/bin/false
hplip:x:114:7:HPLIP system user,,,:/var/run/hplip:/bin/false
kernoops:x:115:65534:Kernel Oops Tracking Daemon,,,:/:/bin/false
pulse:x:116:124:PulseAudio daemon,,,:/var/run/pulse:/bin/false
rtkit:x:117:126:RealtimeKit,,,:/proc:/bin/false
saned:x:118:127::/var/lib/saned:/bin/false
usbmux:x:119:46:usbmux daemon,,,:/var/lib/usbmux:/bin/false
speech-dispatcher:x:120:29:Speech Dispatcher,,,:/var/run/speech-dispatcher:/bin/false
user:x:1000:1000:user,,,:/home/user:/bin/bash
sshd:x:121:65534::/var/run/sshd:/usr/sbin/nologin

这是正确的,但该过程永远不会结束。我必须按 ctrl+c 才能退出。我在命令行中缺少什么?

我之前问过一个问题,但事实证明这个错误是我之前的问题错误的原因,所以我陷入了双重麻烦。

答案1

管道的所有部分几乎同时启动。只有输入/输出才能同步管道的不同阶段。

在你的管道中,

wc -l | sort -t":" -k4,4n | uniq password_demo.txt

uniq将从给定文件获取输入,同时wc -l等待来自其标准输入的输入(在本例中无论您在终端输入什么内容),sort并将等待来自wc.如果它获得任何输入,则 的输出sort将被丢弃,因为该uniq进程不会读取它。


要计算文件中有多少个唯一行:

sort -u password_demo.txt | wc -l

不需要 和 标志,因为我们对整行感兴趣-t-k-u标志sort仅输出唯一的行。

如果您有兴趣计算第四个:分隔字段有多少个唯一值,则必须提取这些值并对它们进行排序:

awk -F ':' '{ print $4 }' password_demo.txt | sort -u | wc -l

或者:

cut -d ':' -f 4 password_demo.txt | sort -u | wc -l

cut有关这些命令的更多信息,请参阅awk系统手册。

答案2

在 中wc -l | sort -t":" -k4,4n | uniq password_demo.txtuniq正在从文件中读取(并忽略管道)。wc正在等待输入(来自 stdin,终端),因为它没有给出要读取的文件名,因此sort也在等待输入(wc的输出)。您可以用来CtrlD表示终端输入结束并将wc退出。

你的意思sort -t":" -k4,4n password_demo.txt | uniq?或者sort -t":" -k4,4n -u password_demo.txt?我不明白wc -l这里怎么适合。

相关内容