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

  免費注冊 查看新帖 |

Chinaunix

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

[文本處理] 求文本處理優(yōu)化思路 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2013-03-19 18:28 |只看該作者 |倒序瀏覽
本帖最后由 ljwd1000 于 2013-03-19 18:32 編輯

需求:需要將文本指定段落的匹配行做相應(yīng)的替換,請大家?guī)兔?yōu)化一下代碼及處理的思路,謝謝了

原文本
  1. [root@ tmp]# cat 1
  2.                         4 => array(
  3.                                 'table_name_inc' => "m_",
  4.                                 'mysql_host' => "10.190.141.141:8004",
  5.                                 'mysql_name' => "ytser",
  6.                                 'mysql_pass' => "yOck_123ok",
  7.                                 'mysql_db' => "game2_3",
  8.                                 'java_ip'=>'10.190.242.137:9007',
  9.                                 'java_ip2'=>'10.190.242.137:8001',
  10.                         ),
  11.                         5 => array(
  12.                                 'table_name_inc' => "m_",
  13.                                 'mysql_host' => "10.190.141.141:8004",
  14.                                 'mysql_name' => "ytser",
  15.                                 'mysql_pass' => "yOck_123ok",
  16.                                 'mysql_db' => "game2_5",
  17.                                 'java_ip'=>'10.190.242.86:9007',
  18.                                 'java_ip2'=>'10.190.242.86:8001',
  19.                         ),
  20.                         6 => array(
  21.                                 'table_name_inc' => "m_",
  22.                                 'mysql_host' => "10.190.141.141:8004",
  23.                                 'mysql_name' => "ytser",
  24.                                 'mysql_pass' => "yOck_123ok",
  25.                                 'mysql_db' => "game2_5",
  26.                                 'java_ip'=>'10.190.242.86:9007',
  27.                                 'java_ip2'=>'10.190.242.86:8001',
  28.                         ),
  29.           ),
復(fù)制代碼
我自己寫的awk代碼:
  1. [root@ tmp]# cat x.awk

  2. /5 =>/{print;
  3. while(getline k){
  4.     if(k~/mysql_host/){
  5.         print gensub(/([^"]*")([^"]*)(.*)/,"\\18.8.8.8\\3","g",k)
  6.         }
  7.     else{
  8.         if(k~/mysql_name/){
  9.             print gensub(/([^"]*")([^"]*)(.*)/,"\\1test\\3","g",k)
  10.             next;
  11.         }
  12.         else{
  13.             print k
  14.         }
  15.     }
  16. }
  17. }1
復(fù)制代碼
結(jié)果:
  1. [root@ tmp]# awk -f x.awk 1
  2.                         4 => array(
  3.                                 'table_name_inc' => "m_",
  4.                                 'mysql_host' => "10.190.141.141:8004",
  5.                                 'mysql_name' => "ytser",
  6.                                 'mysql_pass' => "yOck_123ok",
  7.                                 'mysql_db' => "game2_3",
  8.                                 'java_ip'=>'10.190.242.137:9007',
  9.                                 'java_ip2'=>'10.190.242.137:8001',
  10.                         ),
  11.                         5 => array(
  12.                                 'table_name_inc' => "m_",
  13.                                 'mysql_host' => "8.8.8.8",
  14.                                 'mysql_name' => "test",
  15.                                 'mysql_pass' => "yOck_123ok",
  16.                                 'mysql_db' => "game2_5",
  17.                                 'java_ip'=>'10.190.242.86:9007',
  18.                                 'java_ip2'=>'10.190.242.86:8001',
  19.                         ),
  20.                         6 => array(
  21.                                 'table_name_inc' => "m_",
  22.                                 'mysql_host' => "10.190.141.141:8004",
  23.                                 'mysql_name' => "ytser",
  24.                                 'mysql_pass' => "yOck_123ok",
  25.                                 'mysql_db' => "game2_5",
  26.                                 'java_ip'=>'10.190.242.86:9007',
  27.                                 'java_ip2'=>'10.190.242.86:8001',
  28.                         ),
  29.           ),
復(fù)制代碼

論壇徽章:
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程序設(shè)計版塊每日發(fā)帖之星
日期:2015-06-16 22:20:002015亞冠之塔什干火車頭
日期:2015-06-20 23:28:22
2 [報告]
發(fā)表于 2013-03-19 19:52 |只看該作者
看看這個如何?
  1. awk '/5 => array\(/{k=1}/),/{k=0}k{if(/mysql_host/)sub($NF,"\"8.8.8.8\",");if(/mysql_name/)sub($NF,"\"test\",")}1'
復(fù)制代碼

論壇徽章:
6
摩羯座
日期:2013-08-24 10:43:10獅子座
日期:2013-08-25 10:27:06天秤座
日期:2013-09-11 20:28:44午馬
日期:2014-09-28 16:06:0015-16賽季CBA聯(lián)賽之八一
日期:2016-12-19 13:55:0515-16賽季CBA聯(lián)賽之天津
日期:2016-12-20 14:01:23
3 [報告]
發(fā)表于 2013-03-19 20:10 |只看該作者
@yestreenstars
學(xué)習(xí)

awk對指定段落的匹配行做相應(yīng)的替換
思路:
匹配段開頭,做個標記,直到匹配到段結(jié)束,取消標記。
判斷在標記存在的時候,將匹配到的行做替換。

論壇徽章:
5
未羊
日期:2014-08-04 16:15:21天秤座
日期:2014-08-13 13:52:372015年辭舊歲徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:112015亞冠之浦和紅鉆
日期:2015-06-29 15:30:48
4 [報告]
發(fā)表于 2013-03-20 08:55 |只看該作者
  1. awk 'BEGIN{RS=ORS="array";FS=OFS="\n"}{if(NR==3)sub(/10.190.141.141:8004/,"8.8.8.8")sub(/ytser/,"test");print $0}'
復(fù)制代碼

論壇徽章:
0
5 [報告]
發(fā)表于 2013-03-20 09:43 |只看該作者
回復(fù) 2# yestreenstars


    多謝,學(xué)習(xí)了

論壇徽章:
0
6 [報告]
發(fā)表于 2013-03-20 09:45 |只看該作者
回復(fù) 4# dn833


    多謝,學(xué)習(xí)了
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(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