我正在尝试从 /dev/urandom 中读取一些字节,只保留我可以轻松输入的字节,并将结果修剪为 30 个字符。但是,当数据来自管道时,我无法弄清楚如何获得“仅 30 个字符”的行为。我试过了
cat /dev/urandom | tr -cd 'A-Za-z0-9' | cut -c -30
和
cut -c -30 /dev/urandom | tr -cd 'A-Za-z0-9' | cut -c -30
但这些挂起而不显示任何内容。另一方面,
cut -c -30 /dev/urandom | tr -cd 'A-Za-z0-9'
无休止地输出数据(尽管它显然已被处理,tr
因为只有指定的字符出现在输出中)。
一般来说,如何从管道中读取一定数量的字符(或字节)然后关闭管道?
cut
将读取输入直到文件结束,并从每一行中剪切一部分。使用前两个命令,您什么都看不到,因为tr
删除了任何换行符,因此cut
永远看不到要处理的完整行。最后,tr
再次删除换行符,因此您看不到将cut
行保持在一定长度上的效果。假设您的
head
实用程序支持该选项,您可以使用它来获取固定数量的字节。如果没有,请使用. ( )-c <characters>
dd
dd bs=1 count=NNN < /dev/urandom
因此,这将产生 32 个字母数字(和一个尾随换行符):
虽然,只是出于原则,这有点浪费,因为
tr
扔掉了大约 3/4 或原始输入字节。将原始数据传递urandom
给类似base64
或任何产生十六进制转储的东西可能会更好。将任何东西变成可读字符的一种简单方法: