263

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

4

11 回答 11

482

你不需要cat

head -1 file

会正常工作。

于 2011-05-24T17:06:12.740 回答
80

你没有,head改用。

head -n 1 file.txt
于 2011-05-24T17:07:24.753 回答
46

有很多不同的方法:

sed -n 1p file
head -n 1 file
awk 'NR==1' file
于 2012-07-06T12:17:22.563 回答
23

您可以使用cat file.txt | head -1,但直接使用 head 可能会更好,如head -1 file.txt.

于 2011-05-24T17:07:15.253 回答
16

这可能是不可能的cat。你有理由使用cat吗?

如果您只需要使用 bash 命令执行此操作,这应该适合您:

head -n 1 file.txt
于 2011-05-24T17:07:17.940 回答
10

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

 cat <file> | awk 'NR == 1'
于 2011-05-24T17:16:13.863 回答
6

我很惊讶这个问题一直存在,而且还没有人提供 pre-mapfile 内置方法。

IFS= read -r first_line <file

...将文件的第一行放在扩展为 的变量中"$first_line",就这么简单。

此外,由于read内置在 bash 中并且这种用法不需要​​子shell,因此它比涉及子进程的方法(例如heador awk.

于 2014-02-17T18:50:03.600 回答
3

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

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

或者如果你真的想要cat

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

:)

于 2011-05-24T19:16:46.643 回答
3

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

head -1 FileName.csv
于 2018-07-26T08:01:45.703 回答
0

这个问题有很多很好的答案。如果你愿意的话,就再放一个到篮子里lolcat

lolcat FileName.csv | head -n 1
于 2020-09-24T12:51:35.777 回答
0

在列表中添加一个更令人讨厌的替代方案:

perl -pe'$.<=1||last' file
# or 
perl -pe'$.<=1||last' < file
# or
cat file | perl -pe'$.<=1||last'
于 2020-11-03T23:35:45.287 回答