免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 3113 | 回复: 12

[文本处理] sed替换 [复制链接]

论坛徽章:
1
CU十二周年纪念徽章
日期:2013-10-24 15:41:34
发表于 2013-03-19 00:05 |显示全部楼层
如何把最后一个逗号去掉:
  1. create table tablename
  2. ( id int,
  3.   id2 int,
  4. );
复制代码
变为
  1. create table tablename
  2. ( id int,
  3.   id2 int
  4. );
复制代码

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015年亚洲杯之朝鲜
日期:2015-03-13 22:47:33IT运维版块每日发帖之星
日期:2016-01-09 06:20:00IT运维版块每周发帖之星
日期:2016-03-07 16:27:44
发表于 2013-03-19 05:51 |显示全部楼层
try

  1. sed 'N;s/,\(\n.*)\)/\1/;P;D' urfile
复制代码

论坛徽章:
32
处女座
日期:2013-11-20 23:41:20双子座
日期:2014-06-11 17:20:43戌狗
日期:2014-06-16 11:05:00处女座
日期:2014-07-22 17:30:47狮子座
日期:2014-07-28 15:38:17金牛座
日期:2014-08-05 16:34:01亥猪
日期:2014-08-18 13:34:25白羊座
日期:2014-09-02 15:03:55金牛座
日期:2014-11-10 10:23:58处女座
日期:2014-12-02 09:17:52程序设计版块每日发帖之星
日期:2015-06-16 22:20:002015亚冠之塔什干火车头
日期:2015-06-20 23:28:22
发表于 2013-03-19 09:03 |显示全部楼层
  1. sed -r ':1;N;$!b1;s/(.*),/\1/'
复制代码

论坛徽章:
1
CU十二周年纪念徽章
日期:2013-10-24 15:41:34
发表于 2013-03-19 16:02 |显示全部楼层
回复 2# blackold


    不行,把所有逗号都删除了

论坛徽章:
1
CU十二周年纪念徽章
日期:2013-10-24 15:41:34
发表于 2013-03-19 16:06 |显示全部楼层
回复 3# yestreenstars


    这样是可以,但是会影响到正确的create table语句,因为我做的是批量替换,最好是能匹配逗号后面跟一个换行符和 );  然后替换成);

论坛徽章:
32
处女座
日期:2013-11-20 23:41:20双子座
日期:2014-06-11 17:20:43戌狗
日期:2014-06-16 11:05:00处女座
日期:2014-07-22 17:30:47狮子座
日期:2014-07-28 15:38:17金牛座
日期:2014-08-05 16:34:01亥猪
日期:2014-08-18 13:34:25白羊座
日期:2014-09-02 15:03:55金牛座
日期:2014-11-10 10:23:58处女座
日期:2014-12-02 09:17:52程序设计版块每日发帖之星
日期:2015-06-16 22:20:002015亚冠之塔什干火车头
日期:2015-06-20 23:28:22
发表于 2013-03-19 16:15 |显示全部楼层
本帖最后由 yestreenstars 于 2013-03-19 16:18 编辑
  1. sed '/create table/{:1;N;s/,\(\n);\)/\1/;T1}'
复制代码

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015年亚洲杯之朝鲜
日期:2015-03-13 22:47:33IT运维版块每日发帖之星
日期:2016-01-09 06:20:00IT运维版块每周发帖之星
日期:2016-03-07 16:27:44
发表于 2013-03-19 17:59 |显示全部楼层
回复 4# ecjtubaowp
  1. $ cat urfile
  2. create table tablename
  3. ( id int,
  4. id2 int,
  5. );
复制代码
  1. $ sed 'N;s/,\(\n.*)\)/\1/;P;D' urfile
  2. create table tablename
  3. ( id int,
  4. id2 int
  5. );
复制代码

论坛徽章:
3
水瓶座
日期:2014-03-25 17:08:042015亚冠之塔什干棉农
日期:2015-08-10 10:45:122015亚冠之萨济拖拉机
日期:2015-08-13 16:05:24
发表于 2013-03-20 16:05 |显示全部楼层
如果只是这样为什么不sed '3s/\,//g' test ?

论坛徽章:
2
技术图书徽章
日期:2013-10-30 14:37:252015年亚洲杯之伊朗
日期:2015-04-30 13:37:02
发表于 2013-03-20 22:25 |显示全部楼层
本帖最后由 ajdan4q 于 2013-03-20 23:04 编辑

回复 1# ecjtubaowp
  1. awk '{a[j++]=$0};a[j-1]==");"{gsub("," ,"", a[j-2])}END{for (i=0;i<j;i++) print a[i]}
复制代码
2
  1. awk '{if ($0==");"){gsub(",","",prev);print prev"\n"$0} else print prev; prev=$0}' new_table.sql
复制代码

论坛徽章:
1
CU十二周年纪念徽章
日期:2013-10-24 15:41:34
发表于 2013-03-20 23:02 |显示全部楼层
回复 8# su8610


    只是一个事例而已,实际情况肯定不是这样的。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

SACC2019中国系统架构师大会

【数字转型 架构演进】SACC2019中国系统架构师大会
2019年10月31日~11月2日第11届中国系统架构师大会(SACC2019)将在北京隆重召开。四大主线并行的演讲模式,1个主会场、20个技术专场、超千人参与的会议规模,100+来自互联网、金融、制造业、电商等领域的嘉宾阵容,将为广大参会者提供一场最具价值的技术交流盛会。




----------------------------------------

大会官网>>
  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP