linux文件提取

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. 输入多行内容至文件

输入多行内容至文件

linux 追加多行文件,linux每行追加内容

7. awk 命令使用详解

awk 命令使用详解

8. 删除文件的一行一列

sed '1d' filename.txt
awk '{$1 = "\b"; print $0}' filename.txt
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值