免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1705 | 回复: 6
打印 上一主题 下一主题

使用join时遇到的诡异问题... [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-08-24 10:30 |只看该作者 |倒序浏览
有两个文件:
file1:
9733115
9733909

file2:

973315,gs,937
973315,hain,898
973315,hain,898
973315,js,516
973315,js,518
973315,jx,791
973315,sd,535
973315,zj,577
973315,zj,579
973315,zj,579
973333,bj,10
9733005,hain,898
9733009,heb,316
9733009,heb,316
9733009,heb,316
9733009,heb,316
9733112,hain,898
9733115,ah,552
9733115,ah,552
9733115,ah,555
9733115,ah,555
9733115,ah,555
9733115,bj,10
9733909,bj,10
9733909,bj,10
9733909,bj,10
9733909,bj,10
9733909,bj,10
9733909,bj,10
9733909,bj,10
9733909,bj,10
9733909,bj,10

file1和file2要通过各自的第一个字匹配,但只有9733909 join上了,9733115却join不上,不知何故..

另外,能实现类似功能的程序或命令(shell),请大家指点一二

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
2 [报告]
发表于 2006-08-24 10:44 |只看该作者
看新手导航中如何处理两个文件

grep -Ff file1 file2

论坛徽章:
0
3 [报告]
发表于 2006-08-24 15:14 |只看该作者
我在SUNOS5.9,HP_UX11.11,AIX5.2上都试过
grep -f file1 file2
完全可以实现你的要求,不知道你是什么系统

论坛徽章:
0
4 [报告]
发表于 2006-08-24 16:58 |只看该作者
如果第一文件是这样呢:
1,2,YXYYWXT,9733123
1,1,YCXZWY,9733115
1,4,YXYJCPHTTPWXT,8733234
2,1,YYYJJDCPSSOWH,8733111
3,1,YYYJJDCPHTTPSH,8733123
3,2,YXMLJCSHHTTPCP,9733909
4,1,YXSZMMWXTJSSO,8733266

要用它的第四个字段去匹配第二个文件的第一个字段。

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
5 [报告]
发表于 2006-08-24 17:01 |只看该作者
sorry,呵呵,我这也不中

[ 本帖最后由 寂寞烈火 于 2006-8-24 17:09 编辑 ]

论坛徽章:
0
6 [报告]
发表于 2006-08-24 17:05 |只看该作者
在我的机器上9733115 匹配不上。。真是怪了。

论坛徽章:
0
7 [报告]
发表于 2006-08-25 10:18 |只看该作者
原帖由 guochunning 于 2006-8-24 16:58 发表
如果第一文件是这样呢:
1,2,YXYYWXT,9733123
1,1,YCXZWY,9733115
1,4,YXYJCPHTTPWXT,8733234
2,1,YYYJJDCPSSOWH,8733111
3,1,YYYJJDCPHTTPSH,8733123
3,2,YXMLJCSHHTTPCP,9733909
4,1,YXSZMMWXTJSSO,8733 ...


稍微复杂一点,
sed "s/\,/\ /g" file1 > file11
while read line; do
    Key=`echo $line|awk '{prinf $4}'`
    grep $Key file2
done < file11
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP