如何使用cat读取文件的第一行?

如何使用cat读取文件的第一行?

296289 次浏览

你不需要cat

head -1 file

会很好。

你可以使用cat file.txt | head -1,但是直接使用head可能更好,就像在head -1 file.txt中一样。

这对于cat可能是不可能的。是否有必须使用cat的原因?

如果你只是需要用bash命令来做,这应该为你工作:

head -n 1 file.txt

你不需要,使用head代替。

head -n 1 file.txt

单独cat可能是不可能的,但如果你不想使用head,这是可行的:

 cat <file> | awk 'NR == 1'

如果您有bash v4+,则不需要任何外部命令

< file.txt mapfile -n1 && echo ${MAPFILE[0]}

或者如果你真的想要cat

cat file.txt | mapfile -n1 && echo ${MAPFILE[0]}

:)

有很多不同的方法:

sed -n 1p file
head -n 1 file
awk 'NR==1' file

我很惊讶这个问题已经存在了这么久,而且还没有人提供pre-mapfile内置方法。

IFS= read -r first_line <file

...将文件的第一行放入由"$first_line"展开的变量中,就这么简单。

此外,由于read内置于bash中,并且这种用法不需要子shell,因此它比涉及headawk等子进程的方法要有效得多。

使用下面的命令从CSV文件或任何文件格式中获取第一行。

head -1 FileName.csv

这个问题有很多好的答案。如果你想用lolcat来做,只需要再放一个到篮子里

lolcat FileName.csv | head -n 1

清单上又多了一个讨厌的选择:

perl -pe'$.<=1||last' file
# or
perl -pe'$.<=1||last' < file
# or
cat file | perl -pe'$.<=1||last'