Linux - 限制文本的长度

时间:2017-03-16 16:08:02

标签: linux

我想通过列在不同文件上的名称来提取一些列。

我在以下链接中找到了这个有用的代码:AWK extract columns from file based on header selected from 2nd file

我尝试编辑一些打印标题并限制标题的长度。

#!/bin/bash

DATAFILE=${1:-data.txt}
COLUMNFILE=${2:-list.txt}

awk -v colsFile="$COLUMNFILE" '
   BEGIN {
     j=1
     while ((getline < colsFile) > 0) {
        col[j++] = $1
     }
     n=j-1;
     close(colsFile)
     for (i=1; i<=n; i++) s[col[i]]=i
   }
   NR==1 {
     for (f=1; f<=NF; f++)
       if ($f in s) c[s[$f]]=f
       printf ${$f:0:3}
   }
   { sep=""
     for (f=1; f<=n; f++) {
       printf("%c%s",sep,$c[f])
       sep=" "
     }
     print ""
   }
' "$DATAFILE"

我在之前的链接中使用了相同的例子。

$ cat data.txt
ID,head1,head2,head3,head4
1,25.5,1364.0,22.5,13.2
2,10.1,215.56,1.15,22.2

$ cat list.txt
ID
head1
head4

$ dataExtractor.sh data.txt list.txt
1,25.5,13.2
2,10.1,22.2

我想要的输出是

ID,hea,hea
1,25.5,13.2
2,10.1,22.2

编辑代码以包含$ {$ f:0:3}后,它会给我一个语法错误。 请帮帮我,谢谢!

1 个答案:

答案 0 :(得分:0)

来自man 1 awk

   substr(s, i [, n])      Return  the  at most n-character substring of s
                           starting at i.  If n is omitted, use  the  rest
                           of s.

...

substr($f, 0, 3)