linux系统中批量提取指定行的数据

 

1、测试数据

[root@centos79 test]# cat a.txt
01 3 4
02 f s
03 t 3
04 s d
05 g i
06 y e
07 a w
08 d g
09 e w
10 n u
11 7 8
12 3 s
13 a d
14 g e
15 w a
16 z v
17 n m
18 k p

 

2、提取 3,5,7,8,9,15,17行

使用sed

[root@centos79 test]# ls
a.txt  lines
[root@centos79 test]# cat lines
3
5
7
8
9
15
17
[root@centos79 test]# cat a.txt
01 3 4
02 f s
03 t 3
04 s d
05 g i
06 y e
07 a w
08 d g
09 e w
10 n u
11 7 8
12 3 s
13 a d
14 g e
15 w a
16 z v
17 n m
18 k p
[root@centos79 test]# for i in `cat lines`; do sed -n "$i"p a.txt >> result; done
[root@centos79 test]# ls
a.txt  lines  result
[root@centos79 test]# cat result
03 t 3
05 g i
07 a w
08 d g
09 e w
15 w a
17 n m

 

使用awk

[root@centos79 test]# ls
a.txt  lines
[root@centos79 test]# cat a.txt
01 3 4
02 f s
03 t 3
04 s d
05 g i
06 y e
07 a w
08 d g
09 e w
10 n u
11 7 8
12 3 s
13 a d
14 g e
15 w a
16 z v
17 n m
18 k p
[root@centos79 test]# cat lines
3
5
7
8
9
15
17
[root@centos79 test]# for i in $(cat lines ); do awk -v a=$i 'NR == a' a.txt >> result; done
[root@centos79 test]# cat result
03 t 3
05 g i
07 a w
08 d g
09 e w
15 w a
17 n m

 

使用while语句:

[root@centos79 test]# ls
a.txt  lines
[root@centos79 test]# cat a.txt
01 3 4
02 f s
03 t 3
04 s d
05 g i
06 y e
07 a w
08 d g
09 e w
10 n u
11 7 8
12 3 s
13 a d
14 g e
15 w a
16 z v
17 n m
18 k p
[root@centos79 test]# cat lines
3
5
7
8
9
15
17
[root@centos79 test]# cat lines | while read i; do sed -n "$i"p a.txt >> result; done
[root@centos79 test]# cat result
03 t 3
05 g i
07 a w
08 d g
09 e w
15 w a
17 n m

 

while + awk

[root@centos79 test]# ls
a.txt  lines
[root@centos79 test]# cat a.txt
01 3 4
02 f s
03 t 3
04 s d
05 g i
06 y e
07 a w
08 d g
09 e w
10 n u
11 7 8
12 3 s
13 a d
14 g e
15 w a
16 z v
17 n m
18 k p
[root@centos79 test]# cat lines
3
5
7
8
9
15
17
[root@centos79 test]# cat lines | while read i; do awk -v a=$i 'NR == a' a.txt >> result; done
[root@centos79 test]# cat result
03 t 3
05 g i
07 a w
08 d g
09 e w
15 w a
17 n m

 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。