1. 文件的行数和列数
输出文件的列数
awk 'END{print NF}' filename.txt
输出文件的行数
awk 'END{print NR}' filename.txt
2. 将输出内容保存为文件
awk '{print $1}' filename1.txt >> filename2.txt
3. 输出文件对应的行的内容
输出第一行的内容
输出第2,3行的内容
查看文件的前5行
查看文件的后5行
输出第5行开始,显示10行的内容
查看文件,从第5行开始显示
sed -n '1p' filename.txt
sed -n '2,3p' filename.txt
cat filename.txt | head -n 5
cat filename.txt | tail -n 5
cat filename.txt | tail -n +5 | head -n 10
cat a.txt | tail -n +5
输出指定字符串对应的行
grep -n "string" filename.txt
输出第一列,第一列和第三列的内容
awk '{print $1}' filename.txt
awk '{print $1,$3}' filename.txt
提取文件的前几列、中间若干列,后几列数据,几行几列数据
awk '{for(i = 1; i <= 5; i++) printf("%s ", $i); printf("\n")}' filename.txt
awk '{for(i = 3; i <= 8; i++) printf("%s ", $i); printf("\n")}' filename.txt
awk '{for(i = NF - 5 + 1; i <= NF; i++) printf("%s ", $i); printf("\n")}' filename.txt
awk '{for(i = 2; i <= 5; i++) printf("%s ", $i); {print $8, $9}}' a.txt
提取指定的行,有以下四种方式:
nums.txt包含指定的行数
data.txt数据文件
for i in `cat nums.txt`; do sed -n "$i"p data.txt >> result.txt; done
for i in $(cat nums.txt); do awk -v a=$i 'NR == a' data.txt >> result.txt; done
cat nums.txt | while read i; do sed -n "$i"p data.txt >> result.txt; done
cat nums.txt | while read i; do awk -v a=$i 'NR == a' data.txt >> result.txt; done
提取指定的列
for i in $(cat nums.txt); do awk -v a=$i 'NF == a' data.txt >> result.txt; done
cat nums.txt | while read i; do awk -v a=$i 'NF == a' data.txt >> result.txt; done
4. 将一行数据变为一列
cat filename.txt| xargs -n 1
更多转化方式见列转换为行
5. 比较文件内容
comm [-123] filename1 filename2
diff [options] filename1 filename2
具体可见比较文件内容
6. 输入多行内容至文件
7. awk 命令使用详解
8. 删除文件的一行一列
sed '1d' filename.txt
awk '{$1 = "\b"; print $0}' filename.txt