中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档 | 网通镜像
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > Shell
两个文件如何合并及paste和join的用法
作者:未知 时间:2005-09-13 23:23 出处:Blog.ChinaUnix.net 责编:chinaitpower
              摘要:两个文件如何合并及paste和join的用法

请教这两个文件如何合并?

内容分别如下:
a1:
DAD|15.0|
JAB|2.0|
JAH|55.0|
b1:
DAD|773.0|
GGC|2.0|
JAB|224.0|

如何把它们合在一起内容如下的:
DAD 15.0 773.0
GGC 0 2.0
JAB 2.0 224.0
JAH 55.0 0

cat jj.sh

cat a1 b1 |awk -F"|" '{print }'|sort|uniq >c1
while read line
do
num1=`grep "$line" a1|awk -F"|" '{print }'`
if [ -z "$num1" ]; then
num1=0
fi
num2=`grep "$line" b1|awk -F"|" '{print }'`
if [ -z "$num2" ] ; then
num2=0
fi
echo $line"\t"$num1"\t"$num2
done <c1
测试通过

简化版
cat a1 b1 |awk -F"|" '{print }'|sort|uniq >c1
while read line
do
num1=`grep "$line" a1|awk -F"|" '{print }'`
[ -z "$num1" ] && num1=0
num2=`grep "$line" b1|awk -F"|" '{print }'`
[ -z "$num2" ] && num2=0
echo $line"\t"$num1"\t"$num2
done <c1

我的方法:假设文件已排序
join -t"|" -a1 -a2    a1 b1
DAD|15.0| |773.0|
GGC|2.0|
JAB|2.0| |224.0|0
JAH|55.0|

join -t"|"    a1 b1
DAD|15.0| |773.0|
JAB|2.0| |224.0|


join -t"|"  -v1  a1 b1
JAH|55.0|


join -t"|"  -v2  a1 b1
GGC|2.0|
可将后面三个的输出再用awk整理一下就可满足题目要求

------
两个文件a1,b1
内容分别如下:
a1:
1
2
3
b1:
a
b
c
如何把它们合在一起内容如下的:
1 a
2 b
3 c
-------------

paste -d"\t" a1 a2

关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有