免费注册 查看新帖 |

Chinaunix

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

[文本处理] shell怎么处理列合并 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-09-12 19:20 |只看该作者 |倒序浏览

订单号        下单时间        用户        服务站        付款类型        订单状态        付款状态        发货状态        商品名        商品一级分类
P20150911221340253330        2015/9/11        22:13:40        13787160788        万象凯旋湾服务站        货到付款        未确认        未付款        未发货        雪梨
P20150911221503253331        2015/9/11        22:15:03        13313482205        万象凯旋湾服务站        在线支付        已确认        已付款        已发货        帝皇蕉
P20150911221503253331        2015/9/11        22:15:03        13313482205        万象凯旋湾服务站        在线支付        已确认        已付款        已发货        国产红提
P20150911222858253332        2015/9/11        22:28:58        18175984187        南山苏迪亚诺服务站        货到付款        完成        已付款        已发货        丰华鲜鸡蛋

效果如图:


由于第2列的时间中间多了个空格导致标题错位,即用户列成了时分秒 ,请问如何处理可以将2列和3列的空格去掉或数据合并


请高手指教!!!

论坛徽章:
0
2 [报告]
发表于 2015-09-12 19:54 |只看该作者
awk  'NR>1{$2=$2"_"$3;for(i=3;i<=NF;i++)$i=$(i+1)}1'  tmp5.xls >tmp6.xls

论坛徽章:
1
程序设计版块每日发帖之星
日期:2015-12-24 06:20:00
3 [报告]
发表于 2015-09-13 17:18 |只看该作者
awk  '$1~/^P/{$2=$2"_"$3;$3=" "}1'  tmp5.xls |column -t >tmp6.xls

论坛徽章:
5
白羊座
日期:2014-10-28 11:23:27水瓶座
日期:2015-01-20 10:19:022015亚冠之柏斯波利斯
日期:2015-07-11 18:17:2015-16赛季CBA联赛之同曦
日期:2015-12-23 12:38:582016猴年福章徽章
日期:2016-02-18 15:30:34
4 [报告]
发表于 2015-09-13 17:30 |只看该作者
一般默认excel是按tab分列的,所以可以把除了第二列的空格都替换成tabl即可
  1. sed -r 's/([ ]+)/\t/g;s/\t/ /2' file
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP