何如利用linux shell 脚本实现从不同文件中提取某一列或多列组成新文件
比如说a文件有a1,a2,a3列b文件有b1,b2,b3三列我想组成一个新文件共三列:a1,b2,a3这个如何实现呢~...
比如说a文件有a1,a2,a3列
b文件有b1,b2,b3三列
我想组成一个新文件共三列:a1,b2,a3
这个如何实现呢~ 展开
b文件有b1,b2,b3三列
我想组成一个新文件共三列:a1,b2,a3
这个如何实现呢~ 展开
4个回答
展开全部
楼主可以用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
当然这里有一个限制就是要好统一的分隔符“:”,这是这个命令的不足之处。
肯定还会有其他好的方法,不过我目前就只知道这么多了。
我先编辑了两个文件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.txt 2.txt 3.txt
你需要提取的行含有的关键字是:keyword
新文件的名字是new.txt
那么,运行: cat 1.txt 2.txt 3.txt | grep -i keyword >new.txt
这样就可以得到你想要的文件以及内容。
你需要提取的行含有的关键字是:keyword
新文件的名字是new.txt
那么,运行: cat 1.txt 2.txt 3.txt | grep -i keyword >new.txt
这样就可以得到你想要的文件以及内容。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
假设两个文件名为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
#!/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
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
一般用awk 提取列
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询