zoukankan      html  css  js  c++  java
  • linux系统中sed命令提取指定的行

    1、测试数据如下:

    [root@centos79 test]# seq 10 > a.txt
    [root@centos79 test]# ls
    a.txt
    [root@centos79 test]# cat a.txt
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10

    2、提取第2行

    [root@centos79 test]# cat a.txt
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    [root@centos79 test]# sed -n '2p' a.txt
    2

    3、提取第2行到第7行

    [root@centos79 test]# cat a.txt
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    [root@centos79 test]# sed -n '2,7p' a.txt
    2
    3
    4
    5
    6
    7

    4、只提取第2行和第7行

    [root@centos79 test]# cat a.txt
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    [root@centos79 test]# sed -n '2p;7p' a.txt
    2
    7

    5、提取奇数行

    [root@centos79 test]# cat a.txt
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    [root@centos79 test]# sed -n '1~2p' a.txt
    1
    3
    5
    7
    9

    6、提取偶数行

    [root@centos79 test]# cat a.txt
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    [root@centos79 test]# sed -n '2~2p' a.txt
    2
    4
    6
    8
    10

    7、提取3倍数行

    [root@centos79 test]# cat a.txt
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    [root@centos79 test]# sed -n '3~3p' a.txt
    3
    6
    9

    利用正则表达式提取特定行。

    8、测试数据如下:

    [root@centos79 test]# seq 15 > a.txt
    [root@centos79 test]# cat a.txt
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15

    9、提取匹配2的行

    [root@centos79 test]# cat a.txt
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    [root@centos79 test]# sed -n '/2/p' a.txt
    2
    12

    10、提取没有匹配2的行

    [root@centos79 test]# cat a.txt
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    [root@centos79 test]# sed -n '/2/!p' a.txt
    1
    3
    4
    5
    6
    7
    8
    9
    10
    11
    13
    14
    15

    11、提取同时匹配2和5的行

    [root@centos79 test]# cat a.txt
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    [root@centos79 test]# sed -n '/2|5/p' a.txt
    2
    5
    12
    15

    12、提取没有匹配2或者5的行

    [root@centos79 test]# cat a.txt
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    [root@centos79 test]# sed -n '/2|5/!p' a.txt
    1
    3
    4
    6
    7
    8
    9
    10
    11
    13
    14

    13、提取以2开头的行

    [root@centos79 test]# cat a.txt
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    [root@centos79 test]# sed -n '/^2/p' a.txt
    2

    13、提取以2结尾的行

    [root@centos79 test]# cat a.txt
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    [root@centos79 test]# sed -n '/2$/p' a.txt
    2
    12

    14、同时提取以2开头或者以5开头的行

    [root@centos79 test]# cat a.txt
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    [root@centos79 test]# sed -n '/^2|^5/p' a.txt
    2
    5

    15、同时提取以2和5结尾的行

    [root@centos79 test]# cat a.txt
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    [root@centos79 test]# sed -n '/2$|5$/p' a.txt
    2
    5
    12
    15

    16、提取以1开头以5结尾的行

    [root@centos79 test]# cat a.txt
    1
    2
    3
    4
    5
    6
    7
    8
    9
    13340
    213435
    1332425
    13
    1434
    13245
    [root@centos79 test]# sed -n '/^1.*5$/p' a.txt
    1332425
    13245

    17、提取3的倍数行以外的行

    [root@centos79 test]# cat a.txt
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    [root@centos79 test]# sed -n '3~3!p' a.txt
    1
    2
    4
    5
    7
    8
    10
  • 相关阅读:
    点灯
    流水灯
    <<晨间日记>>要点
    PL/SQL 函数学习 Start with...Connect By
    FTP Put步骤回顾
    ORA16038,ORA19809,ORA00312无法归档的解决方法
    Emacs for windows
    ORA01578,ORA01115,ORA01110 ORACLE 数据块损坏
    MySQL存储过程的调优过程
    ORA01110 数据文件日志文件丢失打不开数据库
  • 原文地址:https://www.cnblogs.com/liujiaxin2018/p/14984096.html
Copyright © 2011-2022 走看看