免费注册 查看新帖 |

Chinaunix

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

请帮忙 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2003-08-08 09:12 |只看该作者 |倒序浏览
假设有这么两个文件
a.txt
**************
2,ABGCF
5,VGFSK
6,JKUHJK
*************

b.txt
*************
AJDHD,4,533
FDGGH,8,766
BJUHT,3,888
ABGCF,5,323
DFDSS,2,333
HGJJJ,8,544
*************

如果a中的第二列在b中的第一列出现即相等
那么我想把b中的这一行写到c.txt中去

例如上面:
a.txt中的第一行的第二列ABGCF等于b.txt中的第四行第一列

那么把b.txt中的第四行ABGCF,5,323写到c.txt中

论坛徽章:
0
2 [报告]
发表于 2003-08-08 09:24 |只看该作者

请帮忙

for i in `cat a.txt`
do
sed -n "/^`echo $i | cut -d "," -f2`\>/p" b.txt >> c.txt
done

论坛徽章:
0
3 [报告]
发表于 2003-08-08 09:48 |只看该作者

请帮忙

楼上写得好,pfpf!!

论坛徽章:
0
4 [报告]
发表于 2003-08-08 09:55 |只看该作者

请帮忙

我本来想用join实现,但我用以下命令进行连接时却失败了,哪位能指点一下:

join -t, -j1 2 -j2 1 a.txt b.txt | cut -d, -f3,4,5

系统无反馈,困惑ing

论坛徽章:
0
5 [报告]
发表于 2003-08-08 10:49 |只看该作者

请帮忙

原帖由 "smileinwind" 发表:
for i in `cat a.txt`
do
sed -n "/^`echo $i | cut -d "," -f2`\>/p" b.txt >> c.txt
done
   


谢谢
,试了,没成功啊,怎么回事?

我还试了下面脚本
for i in `cat a.txt`
do
echo $i
done

为什么执行时什么都不显示?

论坛徽章:
0
6 [报告]
发表于 2003-08-08 10:52 |只看该作者

请帮忙

你的是什么系统?shell?

论坛徽章:
0
7 [报告]
发表于 2003-08-08 10:54 |只看该作者

请帮忙

# cat test
if [ -f c.txt ]
then
rm c.txt
fi
for i in `cat a.txt`
do
sed -n "/^`echo $i | cut -d "," -f2`\>/p" b.txt >> c.txt
done

# sh -x test
+ [ -f c.txt ]
+ rm c.txt
+ cat a.txt
+ echo 2,ABGCF
+ cut -d , -f2
+ sed -n /^ABGCF\>/p b.txt
+ echo 5,VGFSK
+ cut -d , -f2
+ sed -n /^VGFSK\>/p b.txt
+ cut -d , -f2
+ echo 6,JKUHJK
+ sed -n /^JKUHJK\>/p b.txt

我的是solaris8 用sh执行很正常

论坛徽章:
0
8 [报告]
发表于 2003-08-08 11:15 |只看该作者

请帮忙

[quote]原帖由 "smileinwind"]你的是什么系统?shell?[/quote 发表:
     

solaris
ksh

论坛徽章:
1
荣誉版主
日期:2011-11-23 16:44:17
9 [报告]
发表于 2003-08-08 11:16 |只看该作者

请帮忙

原帖由 "zhaoting620" 发表:
我本来想用join实现,但我用以下命令进行连接时却失败了,哪位能指点一下:

join -t, -j1 2 -j2 1 a.txt b.txt | cut -d, -f3,4,5

系统无反馈,困惑ing

先要对源文件进行排序!
sort -t"," +1 a.txt >a
sort -t"," b.txt >b

论坛徽章:
0
10 [报告]
发表于 2003-08-08 11:21 |只看该作者

请帮忙

[quote]原帖由 "smileinwind"]你的是什么系统?shell?[/quote 发表:
     

用你后来那个成功了
太感谢你了
我刚学着用SHELL
以后请多帮忙,看的出你的水平很高
多谢啊
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP