如何使用cat读取文件的第一行?
cat
你不需要cat。
head -1 file
会很好。
你可以使用cat file.txt | head -1,但是直接使用head可能更好,就像在head -1 file.txt中一样。
cat file.txt | head -1
head -1 file.txt
这对于cat可能是不可能的。是否有必须使用cat的原因?
如果你只是需要用bash命令来做,这应该为你工作:
head -n 1 file.txt
你不需要,使用head代替。
head
单独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"展开的变量中,就这么简单。
"$first_line"
此外,由于read内置于bash中,并且这种用法不需要子shell,因此它比涉及head或awk等子进程的方法要有效得多。
read
awk
使用下面的命令从CSV文件或任何文件格式中获取第一行。
head -1 FileName.csv
这个问题有很多好的答案。如果你想用lolcat来做,只需要再放一个到篮子里
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'