如何使用 读取文件的第一行cat
?
问问题
261654 次
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,因此它比涉及子进程的方法(例如head
or 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 回答