免费注册 查看新帖 |

Chinaunix

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

[文本处理] 如何替换数据中最后一列分隔符? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2019-08-12 16:05 |只看该作者 |倒序浏览
本帖最后由 gooderpan 于 2019-08-12 17:23 编辑

比如文件如下以空格作为分隔符:
1 you are a goog woman
2 iam b
3 are a vitb

只想把最后一列的分隔符替换:如下
1 you are a good---woman
2 iam---b
3 are a---vitb

这种形式,各位大神有什么好的方法么?只是想知道mac系统的terminal下面有没有相应的简单的命令

论坛徽章:
0
2 [报告]
发表于 2019-08-12 16:33 |只看该作者
  1. awk '{for(i=0;++i<=NF-1;)printf "%s",i==1?$i:" "$i;printf "---%s",$NF;print ""}' file
复制代码

论坛徽章:
8
2016科比退役纪念章
日期:2018-10-24 08:24:0115-16赛季CBA联赛之北控
日期:2019-03-12 14:34:562016科比退役纪念章
日期:2019-04-01 10:33:0915-16赛季CBA联赛之山东
日期:2019-04-17 12:46:3215-16赛季CBA联赛之广夏
日期:2019-05-09 16:40:4015-16赛季CBA联赛之广夏
日期:2019-10-10 15:33:4015-16赛季CBA联赛之辽宁
日期:2019-10-15 08:37:0615-16赛季CBA联赛之北控
日期:2021-03-30 15:53:34
3 [报告]
发表于 2019-08-12 16:41 |只看该作者
  1. sed -E 's/ (\w+$)/---\1/' file
复制代码

论坛徽章:
0
4 [报告]
发表于 2019-08-12 17:08 |只看该作者
回复 3# cfwyy
你好,我在mac的终端运行,貌似不行呀。请问您这是怎么回事呢??

论坛徽章:
1
19周年集字徽章-年
日期:2020-10-29 09:39:21
5 [报告]
发表于 2019-08-13 11:00 |只看该作者
perl -pe's#.*\K #---#' file

论坛徽章:
0
6 [报告]
发表于 2019-08-13 11:12 |只看该作者
回复 5# legs

谢谢大神,你的命令可以执行。请问,是不是用sed在该处处理的效果不好呀?

论坛徽章:
8
2016科比退役纪念章
日期:2018-10-24 08:24:0115-16赛季CBA联赛之北控
日期:2019-03-12 14:34:562016科比退役纪念章
日期:2019-04-01 10:33:0915-16赛季CBA联赛之山东
日期:2019-04-17 12:46:3215-16赛季CBA联赛之广夏
日期:2019-05-09 16:40:4015-16赛季CBA联赛之广夏
日期:2019-10-10 15:33:4015-16赛季CBA联赛之辽宁
日期:2019-10-15 08:37:0615-16赛季CBA联赛之北控
日期:2021-03-30 15:53:34
7 [报告]
发表于 2019-08-13 12:42 |只看该作者
回复 4# gooderpan

没有mac, 我这好用的。

论坛徽章:
1
19周年集字徽章-年
日期:2020-10-29 09:39:21
8 [报告]
发表于 2019-08-13 14:09 |只看该作者
gooderpan 发表于 2019-08-13 11:12
回复 5# legs 谢谢大神,你的命令可以执行。请问,是不是用sed在该处处理的效果不好呀?

Mac那是非GNU sed,我这FB下用sed可以下面这样用,你试一下:
  1. sed -E 's#(.*) #\1---#'
复制代码



论坛徽章:
50
15-16赛季CBA联赛之广夏
日期:2018-11-05 09:42:462015年亚冠纪念徽章
日期:2015-07-23 11:58:122015亚冠之广州富力
日期:2015-07-07 08:26:172015亚冠之塔什干棉农
日期:2015-06-29 09:08:072015年亚洲杯之伊朗
日期:2015-03-08 20:51:012015年迎新春徽章
日期:2015-03-04 09:58:11未羊
日期:2014-10-16 22:41:47处女座
日期:2014-10-16 15:33:33酉鸡
日期:2014-03-13 12:54:10巳蛇
日期:2014-03-10 14:39:052015亚冠之德黑兰石油
日期:2015-07-29 12:46:372015亚冠之德黑兰石油
日期:2015-08-07 12:54:11
9 [报告]
发表于 2019-08-13 15:32 |只看该作者
  1. awk '$--NF=$(NF-1)"---"$NF' file
复制代码

论坛徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年纪念徽章
日期:2019-08-20 08:30:3720周年集字徽章-周	
日期:2020-10-28 14:13:3020周年集字徽章-20	
日期:2020-10-28 14:04:3019周年集字徽章-CU
日期:2019-09-08 23:26:2519周年集字徽章-19
日期:2019-08-27 13:31:262016科比退役纪念章
日期:2022-04-24 14:33:24
10 [报告]
发表于 2019-08-19 14:21 |只看该作者
回复 4# gooderpan


在你的Mac里面分别试试:
  1. sed 's/ \(\w\+\)$/---\1/' 1.txt
复制代码
  1. sed 's/ \([^ ]\+\)$/---\1/' 1.txt
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP