免费注册 查看新帖 |

Chinaunix

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

[文本处理] 请教关于sed替换的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2016-08-25 16:38 |只看该作者 |倒序浏览
文本如下:
INSERT INTO table_a VALUES ('a', 'b'), ('c', 'd');

替换后的结果:
INSERT INTO table_a VALUES ('a', 'b');INSERT INTO table_a VALUES ('c', 'd');

也就是把一行中的),(都替换为起始的INSERT XXX,sed命令用的不熟悉,请教有什么好方法,谢谢啊。

论坛徽章:
0
2 [报告]
发表于 2016-08-25 16:59 |只看该作者
sed 's#),(#)INSERT INTO table_a(#g'  yourfile

论坛徽章:
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
3 [报告]
发表于 2016-08-25 17:03 |只看该作者
  1. echo "INSERT INTO table_a VALUES ('a', 'b'), ('c', 'd'), ('e', 'f');"|sed -r 's/\), \(/)<(/g;:a;s/(.*VALUES )([^<]*)</\1\2;\n\1/M;ta'
复制代码

INSERT INTO table_a VALUES ('a', 'b');
INSERT INTO table_a VALUES ('c', 'd');
INSERT INTO table_a VALUES ('e', 'f');

论坛徽章:
0
4 [报告]
发表于 2016-08-25 17:04 |只看该作者
回复 2# 拖拉机商人

您好,是我没有说清楚。。。

文本是有很多行的,比如:
INSERT INTO table_a VALUES ('a', 'b'), ('c', 'd');
INSERT INTO table_b VALUES ('a1', 'b'), ('c1', 'd');
INSERT INTO table_c VALUES ('a2', 'b'), ('c2', 'd');

最终替换的结果是:
INSERT INTO table_a VALUES ('a', 'b'); INSERT INTO table_a VALUES ('c', 'd');
INSERT INTO table_b VALUES ('a1', 'b'); INSERT INTO table_b VALUES ('c1', 'd');
INSERT INTO table_c VALUES ('a2', 'b'); INSERT INTO table_c VALUES ('c2', 'd');

论坛徽章:
0
5 [报告]
发表于 2016-08-25 17:46 |只看该作者
本帖最后由 拖拉机商人 于 2016-08-25 17:47 编辑

理解错了,table有规则么?

论坛徽章:
30
申猴
日期:2014-04-10 09:43:532015年亚洲杯纪念徽章
日期:2015-03-20 14:40:232015亚冠之阿尔纳斯尔
日期:2015-06-02 18:59:042015亚冠之阿尔希拉尔
日期:2015-06-30 15:22:572015亚冠之大阪钢巴
日期:2015-07-20 10:44:332015亚冠之阿尔纳斯尔
日期:2015-10-28 14:57:5215-16赛季CBA联赛之新疆
日期:2015-12-25 10:18:45黑曼巴
日期:2016-06-26 21:39:5315-16赛季CBA联赛之山西
日期:2016-07-25 21:54:2715-16赛季CBA联赛之北京
日期:2016-10-27 12:07:2315-16赛季CBA联赛之八一
日期:2017-07-07 16:39:0915-16赛季CBA联赛之吉林
日期:2017-09-04 12:14:43
6 [报告]
发表于 2016-08-25 18:01 |只看该作者
  1. awk -F \( 'gsub("),",");"$1,$0)' OFS="("  file
复制代码
回复 1# wzabcd1234


论坛徽章:
4
程序设计版块每日发帖之星
日期:2016-08-11 06:20:00数据库技术版块每日发帖之星
日期:2016-08-13 06:20:00程序设计版块每日发帖之星
日期:2016-08-14 06:20:00数据库技术版块每日发帖之星
日期:2016-08-14 06:20:00
7 [报告]
发表于 2016-08-25 18:37 |只看该作者
  1. root@localhost:~# str="INSERT INTO table_a VALUES ('a', 'b'), ('c', 'd');"
  2. root@localhost:~# echo $str | sed -e 's:),:);INSERT INTO table_a VALUES :'
  3. INSERT INTO table_a VALUES ('a', 'b');INSERT INTO table_a VALUES  ('c', 'd');
复制代码

论坛徽章:
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
8 [报告]
发表于 2016-08-25 19:34 |只看该作者
  1. sed -r 's/\), \(/)<(/g;:a;s/([^(]*)([^<]*)</\1\2;\n\1/M;ta;s/\n//g'
复制代码

论坛徽章:
0
9 [报告]
发表于 2016-08-25 20:52 |只看该作者
本帖最后由 blind_fish 于 2016-08-25 20:54 编辑

[root@CentOS6min ~]# cat c.txt
INSERT INTO table_a VALUES ('a', 'b'), ('c', 'd');
INSERT INTO table_b VALUES ('a1', 'b'), ('c1', 'd');
INSERT INTO table_c VALUES ('a2', 'b'), ('c2', 'd');
[root@CentOS6min ~]#sed -nr "s@^([^\(]+)(.*)\,(.*,.*)@\1\2;\1\3@p"  c.txt
INSERT INTO table_a VALUES ('a', 'b');INSERT INTO table_a VALUES  ('c', 'd');
INSERT INTO table_b VALUES ('a1', 'b');INSERT INTO table_b VALUES  ('c1', 'd');
INSERT INTO table_c VALUES ('a2', 'b');INSERT INTO table_c VALUES  ('c2', 'd');


您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP