免费注册 查看新帖 |

Chinaunix

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

awk 处理最后一列的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-08-20 21:50 |只看该作者 |倒序浏览
批量文本处理,最后一列101后都有2个“,”,只有一个“,”的加一个逗号,如果没有的加2个“,”;有2个“,”的不要加
这个用怎么实现?比如
000010,小陈,525,0,101
000011,张三,826,0,101,,
000012,里斯,117,0,101
000013,周五,148,0,101,,
000015,陈其,220,0,101,
000016,严五,141,0,101,,
000017,陈好,722,0,101,,
000018,朱文,322,0,101,
000019,倪在,734,0,101,,
000020,潘文,865,0,101,,
000021,周届,226,0,101,

最后成
000010,小陈,525,0,101,,
000011,张三,826,0,101,,
000012,里斯,117,0,101,,
000013,周五,148,0,101,,
000015,陈其,220,0,101,,
000016,严五,141,0,101,,
000017,陈好,722,0,101,,
000018,朱文,322,0,101,,
000019,倪在,734,0,101,,
000020,潘文,865,0,101,,
000021,周届,226,0,101,,

论坛徽章:
0
2 [报告]
发表于 2007-08-20 21:54 |只看该作者
sed -e 's/,\{1,\}[ ]*$//'  -e 's/$/,,/' ur-file

论坛徽章:
0
3 [报告]
发表于 2007-08-20 22:39 |只看该作者

回复 #1 ccx8010 的帖子

笨办法:
sed "s/,$//g" src | sed "s/,$//g" | sed "s/.*/&,,/g"

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

回复 #1 ccx8010 的帖子

awk 'BEGIN { FS=",";OFS="," } {$6="";$7="";print $0}' urfile

论坛徽章:
0
5 [报告]
发表于 2007-08-21 11:04 |只看该作者
:em11: 试了一下用用awk可以这样
cat test.txt |awk -F,0, '{if (($2!="101,," or ($2="101,,"){$2="101,,";print $0}}'

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
6 [报告]
发表于 2007-08-21 11:22 |只看该作者
sed 's/,*$/,,/' urfile

论坛徽章:
0
7 [报告]
发表于 2007-08-21 11:29 |只看该作者
原帖由 ly5066113 于 2007-8-21 11:22 发表
sed 's/,*$/,,/' urfile


这个很简单,但是能解释一下为什么结尾没有","的行也能被匹配到呢?

论坛徽章:
0
8 [报告]
发表于 2007-08-21 11:30 |只看该作者
awk -F,101 '{print $1",101,,"}' file

[ 本帖最后由 galford433 于 2007-8-21 11:33 编辑 ]

论坛徽章:
23
15-16赛季CBA联赛之吉林
日期:2017-12-21 16:39:27白羊座
日期:2014-10-27 11:14:37申猴
日期:2014-10-23 08:36:23金牛座
日期:2014-09-30 08:26:49午马
日期:2014-09-29 09:40:16射手座
日期:2014-11-25 08:56:112015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:0315-16赛季CBA联赛之山东
日期:2017-12-21 16:39:1915-16赛季CBA联赛之广东
日期:2016-01-19 13:33:372015亚冠之山东鲁能
日期:2015-10-13 09:39:062015亚冠之西悉尼流浪者
日期:2015-09-21 08:27:57
9 [报告]
发表于 2007-08-21 11:41 |只看该作者
原帖由 chyhao 于 2007-8-21 11:29 发表


这个很简单,但是能解释一下为什么结尾没有","的行也能被匹配到呢?


正则表达式里面,*代表0个或任意多个。

论坛徽章:
0
10 [报告]
发表于 2007-08-21 11:48 |只看该作者
原帖由 ly5066113 于 2007-8-21 11:41 发表


正则表达式里面,*代表0个或任意多个。

谢谢,学习了!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP