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

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

Chinaunix

  平臺(tái) 論壇 博客 文庫
1234下一頁
最近訪問板塊 發(fā)新帖
查看: 6907 | 回復(fù): 32
打印 上一主題 下一主題

靈活替換的問題,sed,awk均可 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2010-05-13 15:44 |只看該作者 |倒序?yàn)g覽
目的:要將文本中每行的時(shí)間字段,如'20100510161212'替換為to_date('20100510161212','yyyymmddhh24Miss')

文本如下:
insert into info values('23399','136.2.2.2','132.1.4.122','NIC_20100329.0001','4096','20100510161212','20100510161214');
insert into info values('23400','136.2.2.2','132.1.4.122','NIC_20100328.0001','4096','20100510161212','20100510161214');
insert into info values('23401','136.2.2.2','132.1.4.122','NIC_20100328.0001','4096','20100510161212','20100510161214');

替換后的文本:
insert into info values('23399','136.2.2.2','132.1.4.122','NIC_20100329.0001','4096',to_date('20100510161212','yyyymmddhh24Miss'),to_date('20100510161214','yyyymmddhh24Miss'));
insert into info values('23400','136.2.2.2','132.1.4.122','NIC_20100328.0001','4096',to_date('20100510161212','yyyymmddhh24Miss'),to_date('20100510161214','yyyymmddhh24Miss'));
insert into info values('23401','136.2.2.2','132.1.4.122','NIC_20100328.0001','4096',to_date('20100510161212','yyyymmddhh24Miss'),to_date('20100510161214','yyyymmddhh24Miss'));

PS:文本中時(shí)間字段的位置可能不同,比如這個(gè)文本,以“,”為分隔符,時(shí)間字段是第6,7兩個(gè)字段?赡芰硗庖粋(gè)文本是在2,3,4字段。

論壇徽章:
0
2 [報(bào)告]
發(fā)表于 2010-05-13 15:46 |只看該作者
說明一下,每個(gè)文本,我是可以根據(jù)文件名判斷出,時(shí)間字段是分布在哪幾個(gè)位置。

論壇徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年紀(jì)念徽章
日期: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科比退役紀(jì)念章
日期:2022-04-24 14:33:24
3 [報(bào)告]
發(fā)表于 2010-05-13 15:49 |只看該作者

  1. sed "s/\('[0-9]\{14\}'\)/to_date(\1,'yyyymmddhh24Miss')/g" urfile
復(fù)制代碼

論壇徽章:
0
4 [報(bào)告]
發(fā)表于 2010-05-13 15:51 |只看該作者

  1. sed -r "s#'[0-9]{14}'#to_date(&,'yyyymmddhh24Miss')#g" FILE
復(fù)制代碼

論壇徽章:
0
5 [報(bào)告]
發(fā)表于 2010-05-13 15:55 |只看該作者
樓上兩位的方法,如果其中也有一個(gè)非時(shí)間字段也是14位的數(shù)字,不就歇菜了。。

論壇徽章:
0
6 [報(bào)告]
發(fā)表于 2010-05-13 15:57 |只看該作者
  1. awk -F"," 'BEGIN{OFS=","}NF >=7{$6="to_date("$6",'\''yyyymmddhh24Miss'\'')"; gsub(/\)|;/,"",$7); $7="to_date("$7",'\''yyyymmddhh24Miss'\'');";}1' file
復(fù)制代碼
第 6,7個(gè)是日期的

論壇徽章:
0
7 [報(bào)告]
發(fā)表于 2010-05-13 15:59 |只看該作者
回復(fù) 2# beauty2003


你可以根據(jù)文件名判斷出時(shí)間字段分布在哪個(gè)位置,但是你不告訴他們,那他們只能這樣根據(jù)字段長度來判斷。

論壇徽章:
0
8 [報(bào)告]
發(fā)表于 2010-05-13 16:00 |只看該作者
回復(fù) 5# beauty2003
你給的例子里并沒有這樣的情況,也沒有說明怎么判斷時(shí)間位置,歇菜也怪不得我們呀…… - -

論壇徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年紀(jì)念徽章
日期: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科比退役紀(jì)念章
日期:2022-04-24 14:33:24
9 [報(bào)告]
發(fā)表于 2010-05-13 16:02 |只看該作者
回復(fù) 5# beauty2003


你的真實(shí)數(shù)據(jù)里面有這樣的例子么?貼出來看看?

論壇徽章:
0
10 [報(bào)告]
發(fā)表于 2010-05-13 16:07 |只看該作者
回復(fù)  beauty2003
你給的例子里并沒有這樣的情況,也沒有說明怎么判斷時(shí)間位置,歇菜也怪不得我們呀……  ...
kwokcn 發(fā)表于 2010-05-13 16:00



比如說文件名中含有_10001,時(shí)間字段是在6,7字段。文件名中含有_10002,是在2,3,4字段。
我是想在配置文件里,搞個(gè)映射關(guān)系,比如
10001=6,7
10002=2,3,4
10003=1,5  這樣的
但是在腳本里,只通過將位置參數(shù)傳入,就可以實(shí)現(xiàn),替換對應(yīng)位置的值。
您需要登錄后才可以回帖 登錄 | 注冊

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

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP