免费注册 查看新帖 |

Chinaunix

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

[文本处理] 请教:两个CSV文件,想保持A一直是B的子集,应该怎么做呢? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-10-24 13:55 |只看该作者 |倒序浏览
A是配置文件用的表格,可能会删除一些列,也可能会增加一些列
B相当于是个A的备份,但是想要B包含A中删除过和增加过的列
例如:
A开始有1,2,3,4列,B也有1,2,3,4列
后来A删除了"3"列,增加了"5"列,即
A:1,2,4,5
我想保持B不仅不删掉A列,但是增加5列,即
B:1,2,3,4,5
应该怎么做呢?

我的笨办法目前是从A中取每一列在B中查找,如果没有就插入到B中
请问如果不用if判断,应该怎么实现呢?

论坛徽章:
39
辰龙
日期:2013-08-21 15:45:192015亚冠之广州富力
日期:2015-05-12 16:34:52亥猪
日期:2015-03-03 17:22:00申猴
日期:2015-03-03 17:21:37未羊
日期:2014-10-10 13:45:41戌狗
日期:2014-06-17 09:53:29巨蟹座
日期:2014-06-12 23:17:17双鱼座
日期:2014-06-10 12:42:44寅虎
日期:2014-06-09 12:52:172015亚冠之卡尔希纳萨夫
日期:2015-05-24 15:24:35黄金圣斗士
日期:2015-12-02 17:25:0815-16赛季CBA联赛之吉林
日期:2017-06-24 16:43:52
2 [报告]
发表于 2013-10-24 18:04 |只看该作者
目测这个是版本控制的菜

论坛徽章:
145
技术图书徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11狮子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龙
日期:2014-01-08 15:26:12技术图书徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
3 [报告]
发表于 2013-10-24 18:37 |只看该作者
回复 1# qooweds

# grep "." A B
A:1,2,3,4
B:1,2,3,4

# awk -F"," '{for(n=0;n++<NF;){if(ARGIND==1){a[$n]=1;add=$0}else{if(a[$n]==""){add=add","$n}}}}END{print add > "B"}' B A

# cat B
1,2,3,4

# echo "1,2,4,5" > A

# awk -F"," '{for(n=0;n++<NF;){if(ARGIND==1){a[$n]=1;add=$0}else{if(a[$n]==""){add=add","$n}}}}END{print add > "B"}' B A

# cat B
1,2,3,4,5

   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP