何如利用linux shell 脚本实现从不同文件中提取某一列或多列组成新文件

比如说a文件有a1,a2,a3列
b文件有b1,b2,b3三列
我想组成一个新文件共三列:a1,b2,a3
这个如何实现呢~

楼主可以用cut命令实现。
我先编辑了两个文件a,b,内容如下
aaa:bbb:ccc
ddd:eee:fff
b文件内容如下:
AAA:BBB:CCC
DDD:EEE:FFF
如果想把a,b中第1,3字段提取出来输出到c文件中,则可这样实现:
cat a b | cut -d ':' -f 1,3 > c
(解释:-d 后接分隔符,这里为冒号,也可以为其他的,看你的具体文件; -f 依据-d分隔符将得到的数个字段的第几字段提取出来,这里是提取第1,3字段)
运行结果:(c文件里的内容)
aaa:ccc
ddd:fff
AAA:CCC
DDD:FFF
当然这里有一个限制就是要好统一的分隔符“:”,这是这个命令的不足之处。
肯定还会有其他好的方法,不过我目前就只知道这么多了。
温馨提示:答案为网友推荐,仅供参考
第1个回答  2011-10-31
假设不同文件的名字是 1.txt 2.txt 3.txt
你需要提取的行含有的关键字是:keyword
新文件的名字是new.txt
那么,运行: cat 1.txt 2.txt 3.txt | grep -i keyword >new.txt

这样就可以得到你想要的文件以及内容。
第2个回答  2011-11-05
假设两个文件名为f1,f2。新文件为f3,分隔符为逗号
#!/bin/bash
TEXT1=`cat "f1"`
TEXT2=`cat "f2"`
RESULT1=`echo "$TEXT1" | awk 'BEGIN {FS=","}{print $1}'`
RESULT2=`echo "$TEXT2" | awk 'BEGIN {FS=","}{print $2}'`
RESULT3=`echo "$TEXT1" | awk 'BEGIN {FS=","}{print $3}'`
echo "$RESULT1" > "f3"
echo "$RESULT2" > "f3"
echo "$RESULT3" > "f3"
exit 0
第3个回答  2011-10-31
一般用awk 提取列本回答被提问者采纳