亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 679 | 回復(fù): 8
打印 上一主題 下一主題

[文本處理] 請教關(guān)于sed替換的問題 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2016-08-25 16:38 |只看該作者 |倒序?yàn)g覽
文本如下:
INSERT INTO table_a VALUES ('a', 'b'), ('c', 'd');

替換后的結(jié)果:
INSERT INTO table_a VALUES ('a', 'b');INSERT INTO table_a VALUES ('c', 'd');

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

論壇徽章:
0
2 [報告]
發(fā)表于 2016-08-25 16:59 |只看該作者
sed 's#),(#)INSERT INTO table_a(#g'  yourfile

論壇徽章:
28
15-16賽季CBA聯(lián)賽之八一
日期:2016-02-22 19:10:4215-16賽季CBA聯(lián)賽之深圳
日期:2016-12-01 10:34:0415-16賽季CBA聯(lián)賽之新疆
日期:2016-12-07 10:24:2915-16賽季CBA聯(lián)賽之同曦
日期:2016-12-15 12:06:43CU十四周年紀(jì)念徽章
日期:2016-12-18 13:03:4415-16賽季CBA聯(lián)賽之吉林
日期:2017-01-03 15:52:2515-16賽季CBA聯(lián)賽之遼寧
日期:2017-01-04 14:58:2415-16賽季CBA聯(lián)賽之遼寧
日期:2017-01-15 09:42:512016科比退役紀(jì)念章
日期:2017-02-06 17:21:50黑曼巴
日期:2017-02-10 15:46:1215-16賽季CBA聯(lián)賽之上海
日期:2017-03-18 10:14:5415-16賽季CBA聯(lián)賽之青島
日期:2017-03-18 22:00:44
3 [報告]
發(fā)表于 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'
復(fù)制代碼

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

論壇徽章:
0
4 [報告]
發(fā)表于 2016-08-25 17:04 |只看該作者
回復(fù) 2# 拖拉機(jī)商人

您好,是我沒有說清楚。。。

文本是有很多行的,比如:
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');

最終替換的結(jié)果是:
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 [報告]
發(fā)表于 2016-08-25 17:46 |只看該作者
本帖最后由 拖拉機(jī)商人 于 2016-08-25 17:47 編輯

理解錯了,table有規(guī)則么?

論壇徽章:
30
申猴
日期:2014-04-10 09:43:532015年亞洲杯紀(jì)念徽章
日期:2015-03-20 14:40:232015亞冠之阿爾納斯?fàn)?日期:2015-06-02 18:59:042015亞冠之阿爾希拉爾
日期:2015-06-30 15:22:572015亞冠之大阪鋼巴
日期:2015-07-20 10:44:332015亞冠之阿爾納斯?fàn)?日期:2015-10-28 14:57:5215-16賽季CBA聯(lián)賽之新疆
日期:2015-12-25 10:18:45黑曼巴
日期:2016-06-26 21:39:5315-16賽季CBA聯(lián)賽之山西
日期:2016-07-25 21:54:2715-16賽季CBA聯(lián)賽之北京
日期:2016-10-27 12:07:2315-16賽季CBA聯(lián)賽之八一
日期:2017-07-07 16:39:0915-16賽季CBA聯(lián)賽之吉林
日期:2017-09-04 12:14:43
6 [報告]
發(fā)表于 2016-08-25 18:01 |只看該作者
  1. awk -F \( 'gsub("),",");"$1,$0)' OFS="("  file
復(fù)制代碼
回復(fù) 1# wzabcd1234


論壇徽章:
4
程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2016-08-11 06:20:00數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2016-08-13 06:20:00程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2016-08-14 06:20:00數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2016-08-14 06:20:00
7 [報告]
發(fā)表于 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');
復(fù)制代碼

論壇徽章:
28
15-16賽季CBA聯(lián)賽之八一
日期:2016-02-22 19:10:4215-16賽季CBA聯(lián)賽之深圳
日期:2016-12-01 10:34:0415-16賽季CBA聯(lián)賽之新疆
日期:2016-12-07 10:24:2915-16賽季CBA聯(lián)賽之同曦
日期:2016-12-15 12:06:43CU十四周年紀(jì)念徽章
日期:2016-12-18 13:03:4415-16賽季CBA聯(lián)賽之吉林
日期:2017-01-03 15:52:2515-16賽季CBA聯(lián)賽之遼寧
日期:2017-01-04 14:58:2415-16賽季CBA聯(lián)賽之遼寧
日期:2017-01-15 09:42:512016科比退役紀(jì)念章
日期:2017-02-06 17:21:50黑曼巴
日期:2017-02-10 15:46:1215-16賽季CBA聯(lián)賽之上海
日期:2017-03-18 10:14:5415-16賽季CBA聯(lián)賽之青島
日期:2017-03-18 22:00:44
8 [報告]
發(fā)表于 2016-08-25 19:34 |只看該作者
  1. sed -r 's/\), \(/)<(/g;:a;s/([^(]*)([^<]*)</\1\2;\n\1/M;ta;s/\n//g'
復(fù)制代碼

論壇徽章:
0
9 [報告]
發(fā)表于 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');


您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP