zoukankan      html  css  js  c++  java
  • linux系统中实现文本转置

    1、

    [root@centos7 test]# cat a.txt
    01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20
    21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
    41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60
    61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80
    [root@centos7 test]# for i in `seq $(head -n 1 a.txt | awk '{print NF}')`; do cut -d " " -f $i a.txt | tr "\n" " "| sed '$ s/$/\n/' >> b.txt; done
    [root@centos7 test]# ls
    a.txt  b.txt
    [root@centos7 test]# cat b.txt
    01 21 41 61
    02 22 42 62
    03 23 43 63
    04 24 44 64
    05 25 45 65
    06 26 46 66
    07 27 47 67
    08 28 48 68
    09 29 49 69
    10 30 50 70
    11 31 51 71
    12 32 52 72
    13 33 53 73
    14 34 54 74
    15 35 55 75
    16 36 56 76
    17 37 57 77
    18 38 58 78
    19 39 59 79
    20 40 60 80

    2、

    [root@centos7 test]# cat a.txt
    01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20
    21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
    41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60
    61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80
    [root@centos7 test]# for i in `seq $(head -n 1 a.txt | awk '{print NF}')`; do awk -v a=$i '{print $a}' a.txt | awk BEGIN{RS=EOF}'{gsub("\n"," ");print}' >> c.txt; done
    [root@centos7 test]# cat c.txt
    01 21 41 61
    02 22 42 62
    03 23 43 63
    04 24 44 64
    05 25 45 65
    06 26 46 66
    07 27 47 67
    08 28 48 68
    09 29 49 69
    10 30 50 70
    11 31 51 71
    12 32 52 72
    13 33 53 73
    14 34 54 74
    15 35 55 75
    16 36 56 76
    17 37 57 77
    18 38 58 78
    19 39 59 79
    20 40 60 80

    3、

    [root@centos7 test]# cat a.txt
    01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20
    21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
    41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60
    61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80
    [root@centos7 test]# for i in `seq $(awk '{print NF}' a.txt | head -n 1)`; do awk -v a=$i '{print $a}' a.txt | xargs >> d.txt; done
    [root@centos7 test]# cat d.txt
    01 21 41 61
    02 22 42 62
    03 23 43 63
    04 24 44 64
    05 25 45 65
    06 26 46 66
    07 27 47 67
    08 28 48 68
    09 29 49 69
    10 30 50 70
    11 31 51 71
    12 32 52 72
    13 33 53 73
    14 34 54 74
    15 35 55 75
    16 36 56 76
    17 37 57 77
    18 38 58 78
    19 39 59 79
    20 40 60 80

    4、

    [root@centos7 test]# cat a.txt
    01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20
    21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
    41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60
    61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80
    [root@centos7 test]# for i in `seq $(head -n 1 a.txt | awk '{print NF}')`; do cut -d " " -f $i a.txt | sed ':a; N;s/\n/ /; ta' >> e.txt;done
    [root@centos7 test]# cat e.txt
    01 21 41 61
    02 22 42 62
    03 23 43 63
    04 24 44 64
    05 25 45 65
    06 26 46 66
    07 27 47 67
    08 28 48 68
    09 29 49 69
    10 30 50 70
    11 31 51 71
    12 32 52 72
    13 33 53 73
    14 34 54 74
    15 35 55 75
    16 36 56 76
    17 37 57 77
    18 38 58 78
    19 39 59 79
    20 40 60 80
  • 相关阅读:
    Hystrix框架4--circuit
    Hystrix框架3--线程池
    undo tablespace RETENTION GUARANTEE
    Xshell访问虚拟机
    SQL Server nvarchar(max)
    win10 D盘空间占用太大(内容和标题可能不符,慎入)
    Grid Control安装和Deployment agent
    /etc/oratab
    Environment variable ORACLE_UNQNAME not defined.Please set ORACLE_UNQNAME to database unique name.
    Oracle的listener.ora、tnsnames.ora的配置
  • 原文地址:https://www.cnblogs.com/liujiaxin2018/p/14663533.html
Copyright © 2011-2022 走看看