免费注册 查看新帖 |

Chinaunix

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

修改文件某列内容 [复制链接]

论坛徽章:
28
15-16赛季CBA联赛之八一
日期:2016-02-22 19:10:4215-16赛季CBA联赛之深圳
日期:2016-12-01 10:34:0415-16赛季CBA联赛之新疆
日期:2016-12-07 10:24:2915-16赛季CBA联赛之同曦
日期:2016-12-15 12:06:43CU十四周年纪念徽章
日期:2016-12-18 13:03:4415-16赛季CBA联赛之吉林
日期:2017-01-03 15:52:2515-16赛季CBA联赛之辽宁
日期:2017-01-04 14:58:2415-16赛季CBA联赛之辽宁
日期:2017-01-15 09:42:512016科比退役纪念章
日期:2017-02-06 17:21:50黑曼巴
日期:2017-02-10 15:46:1215-16赛季CBA联赛之上海
日期:2017-03-18 10:14:5415-16赛季CBA联赛之青岛
日期:2017-03-18 22:00:44
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-01-25 15:00 |只看该作者 |倒序浏览
本帖最后由 moperyblue 于 2016-07-19 13:12 编辑

修改原始文件,在第4列数据前加上数字零(0),如何实现呢?

原始文件内容:
A1|120516005958|901|813|4080|81171
A1|120516005959|8D0|813|1941|32964
A1|120516005959|8D1|813|1C60|75008

结果:
A1|120516005958|901|0813|4080|81171
A1|120516005959|8D0|0813|1941|32964
A1|120516005959|8D1|0813|1C60|75008

用sed:sed -r -i 's/(.*)\|(.*)\|(.*)\|(.*)\|(.*)\|(.*)/\1|\2|\3|0\4|\5|\6/g' a
  
如果每行数据的列数有几十列用上面的这种方法比较麻烦,有其它简单的方法吗?

参考方法:
  1. sed 's/[^|]*/0&/4'
  2. sed 's/|/&0/3'
复制代码

论坛徽章:
8
技术图书徽章
日期:2013-08-22 11:21:28未羊
日期:2015-01-19 22:22:25巳蛇
日期:2014-08-11 16:53:08子鼠
日期:2014-05-29 09:04:44摩羯座
日期:2014-04-11 14:15:07丑牛
日期:2014-01-24 12:41:28金牛座
日期:2013-11-21 17:38:28射手座
日期:2015-01-21 08:50:32
2 [报告]
发表于 2015-01-25 20:08 |只看该作者
awk -F'|' -vOFS='|' '{$4="0"$4;print}' urfile;

论坛徽章:
0
3 [报告]
发表于 2015-01-29 22:03 |只看该作者
回复 1# moperyblue


    echo "A1|120516005958|901|813|4080|81171
A1|120516005959|8D0|813|1941|32964
A1|120516005959|8D1|813|1C60|75008"|perl -F'\|' -lane '$F[3]="0$F[3]";$,="|";print @F'
A1|120516005958|901|0813|4080|81171
A1|120516005959|8D0|0813|1941|32964
A1|120516005959|8D1|0813|1C60|75008
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP