中国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
  当前位置:> 操作系统 > Linux > Linux综合
shell问答17:用join比较处理某些字段相同的文件
作者:未知 时间:2005-09-13 22:07 出处:Blog.ChinaUnix.net 责编:chinaitpower
              摘要:shell问答17:用join比较处理某些字段相同的文件
整理了一梦如是、mocou、guangzongy和begincwcw的解决方案,以资借鉴!谢过先:)

问:
 # cat aa
123|11|aaaaa
124|12|abasf
125|12|aaccc
126|13|ccccc
127|14|ccvvv
128|17|vgfgd 
# cat bb
12|aaa
12|ddd
13|aaa
14|aaa
要生成
124|12|abasf
124|12|abasf
125|12|aaccc
125|12|aaccc
126|13|ccccc
127|14|ccvvv
既将aa中第二域与bb中第一域相同的记录打印出来,怎样实现?

答案:
1.join -2 1 -1 2 1 2 -t'|' -o 1.1,1.2,1.3
2.for line in `<a.txt` ;do key=`echo $line|cut -d '|' -f2`; [ -z "`grep $key b.txt`" ]||echo $line; done
3.awk的方法
A:
nawk 'BEGIN { FS = "|"; while ((getline < "bb.txt") > 0) { lines[] }}
       { if( in lines)
              print }' aa.txt
以上运行结果为aa.txt在bb.txt存在的。

B:
nawk 'BEGIN { FS = "|"; while ((getline < "bb.txt") > 0) { lines[] }}
         { if( in lines)
                 next
            else
                 print }' aa.txt
以上运行结果为aa.tt在bb.tt不存在的。

C:
nawk 'BEGIN { FS = "|"; while ((getline < "bb.txt") > 0) { lines[] }}
        { if( in lines)
                print "|find"
           else
                print "|not find" }' aa.txt
以上运行结果为aa.txt在bb.txt中找到的打印find,没有找到的打印not find。

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