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

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

Chinaunix

  平臺(tái) 論壇 博客 文庫(kù)
最近訪問(wèn)板塊 發(fā)新帖
查看: 3121 | 回復(fù): 9
打印 上一主題 下一主題

[文本處理] for循環(huán)效率怎樣提升 [復(fù)制鏈接]

論壇徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:54:45
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2018-03-20 14:32 |只看該作者 |倒序?yàn)g覽
樓主需求很簡(jiǎn)單,一個(gè)10億行的文本文件,每行格式都一樣。目的是要把每一行內(nèi)容處理一下格式在加工一下重定向到一個(gè)新文件。

for i in `cat $1`
  do
     k1=`echo $i|awk -F ":" '{print $1}'`
     k2=`echo $i|awk -F ":" '{print $2}'`
     echo $k1@@$k2 >> $1.txt
done
先寫(xiě)一個(gè)簡(jiǎn)單的測(cè)試看看速度怎樣,結(jié)果1秒才處理幾百條,即使把文件分割了,多跑幾個(gè)程序這速度也沒(méi)法接受呀,想看看慢在哪里。

for i in `cat $1`
  do
     echo @ >> $1.txt
done
想想是不是每次都寫(xiě)入文件造成的速度問(wèn)題呢,先去掉變量賦值,直接打印個(gè)字符看看速度怎樣,結(jié)果速度1秒5w。

for i in `cat $1`
  do
     k1=$i
     echo $k1 >> 1.txt
done
現(xiàn)不處理變量,賦值并打印出來(lái),結(jié)果1秒3w

for i in `cat $1`
  do
     k1=`echo $ip`
     echo $k1 >> 1.txt
done
這里我只是換了一個(gè)變量賦值的方法,并且還沒(méi)有做awk的出來(lái),結(jié)果速度就下降到了1秒2000條,很不理解這里是因?yàn)閌`調(diào)用了新的shell執(zhí)行命令造成的嗎。現(xiàn)在還沒(méi)想到awk用什么別的方法處理變量。大家有時(shí)間的看看,有什么好的方法解決。




論壇徽章:
145
技術(shù)圖書(shū)徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11獅子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龍
日期:2014-01-08 15:26:12技術(shù)圖書(shū)徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
2 [報(bào)告]
發(fā)表于 2018-03-20 14:59 |只看該作者
回復(fù) 1# yiguihuo

try below or tell us what you want ...

$ cat FILE
a:b
c:d

$ bash aa.sh FILE

$ cat FILE.txt
a@@b
c@@d

$ cat aa.sh
awk -F: '{print $1"@@"$2}' $1 >> $1.txt

論壇徽章:
24
申猴
日期:2014-10-10 15:56:39射手座
日期:2014-10-10 15:57:18黑曼巴
日期:2018-05-14 11:05:122016科比退役紀(jì)念章
日期:2018-05-14 11:05:0715-16賽季CBA聯(lián)賽之北控
日期:2018-05-14 11:05:0015-16賽季CBA聯(lián)賽之江蘇
日期:2017-02-27 18:11:0715-16賽季CBA聯(lián)賽之上海
日期:2018-08-15 09:48:5415-16賽季CBA聯(lián)賽之佛山
日期:2018-07-20 17:14:2315-16賽季CBA聯(lián)賽之佛山
日期:2019-09-10 18:08:4615-16賽季CBA聯(lián)賽之山西
日期:2020-03-26 09:40:5115-16賽季CBA聯(lián)賽之佛山
日期:2020-05-08 09:03:54
3 [報(bào)告]
發(fā)表于 2018-03-20 15:02 |只看該作者
本帖最后由 chengchow 于 2018-03-20 15:05 編輯

sed -r 's/:/@@/g' file

論壇徽章:
25
程序設(shè)計(jì)版塊每日發(fā)帖之星
日期:2016-05-03 06:20:0015-16賽季CBA聯(lián)賽之八一
日期:2018-07-05 10:34:09黑曼巴
日期:2018-07-06 15:19:5015-16賽季CBA聯(lián)賽之佛山
日期:2018-08-03 13:19:3315-16賽季CBA聯(lián)賽之山西
日期:2018-08-07 19:46:2315-16賽季CBA聯(lián)賽之廣夏
日期:2018-08-08 19:31:5015-16賽季CBA聯(lián)賽之青島
日期:2018-11-26 15:21:5015-16賽季CBA聯(lián)賽之上海
日期:2018-12-11 09:45:3219周年集字徽章-年
日期:2020-04-18 23:54:5215-16賽季CBA聯(lián)賽之深圳
日期:2020-04-19 21:40:19黑曼巴
日期:2022-04-03 17:55:1315-16賽季CBA聯(lián)賽之八一
日期:2018-07-03 16:56:46
4 [報(bào)告]
發(fā)表于 2018-03-20 16:12 |只看該作者
回復(fù) 1# yiguihuo


采用awk這種行處理工具才能提高效率,參考2樓答案。

論壇徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:54:45
5 [報(bào)告]
發(fā)表于 2018-03-20 16:20 |只看該作者
謝謝兩位的解答,為什么要用for循環(huán),主要是想后期處理在添加內(nèi)容方便些。處理的文件用處是向elasticsearch導(dǎo)入。
a:b
c:d
處理后的內(nèi)容是下面這樣
{"index":{"_index":"kt","_type":"list"}}
{"k_1":"a","k_2":"b"}
{"index":{"_index":"kt","_type":"list"}}
{"k_1":"c","k_2":"d"}

論壇徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:54:45
6 [報(bào)告]
發(fā)表于 2018-03-20 17:21 |只看該作者
謝謝上面幾位兄弟的提醒,awk還是很強(qiáng)大的
awk -F ":" '{print "{\"index\":{\"_index\":\"kt\",\"_type\":\"list\"}}""\n""{\"k_1\":\""  $1"\",\"k_2\":\""$2"\"}"}'  kt-00

論壇徽章:
5
2015年辭舊歲徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015年亞洲杯之朝鮮
日期:2015-03-13 22:47:33IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-01-09 06:20:00IT運(yùn)維版塊每周發(fā)帖之星
日期:2016-03-07 16:27:44
7 [報(bào)告]
發(fā)表于 2018-03-21 09:04 |只看該作者
這樣寫(xiě)不慢都不行。

論壇徽章:
0
8 [報(bào)告]
發(fā)表于 2018-03-22 02:02 |只看該作者
提示: 作者被禁止或刪除 內(nèi)容自動(dòng)屏蔽

論壇徽章:
24
申猴
日期:2014-10-10 15:56:39射手座
日期:2014-10-10 15:57:18黑曼巴
日期:2018-05-14 11:05:122016科比退役紀(jì)念章
日期:2018-05-14 11:05:0715-16賽季CBA聯(lián)賽之北控
日期:2018-05-14 11:05:0015-16賽季CBA聯(lián)賽之江蘇
日期:2017-02-27 18:11:0715-16賽季CBA聯(lián)賽之上海
日期:2018-08-15 09:48:5415-16賽季CBA聯(lián)賽之佛山
日期:2018-07-20 17:14:2315-16賽季CBA聯(lián)賽之佛山
日期:2019-09-10 18:08:4615-16賽季CBA聯(lián)賽之山西
日期:2020-03-26 09:40:5115-16賽季CBA聯(lián)賽之佛山
日期:2020-05-08 09:03:54
9 [報(bào)告]
發(fā)表于 2018-03-22 10:47 |只看該作者
閑著無(wú)聊做了下測(cè)試,1000W行,目測(cè)sed效率要高1倍
  1. [root@AnsibleTower_120 tmp]# time awk -F: '{print $1"@@"$2}' 1.txt > 2.txt

  2. real        0m11.645s
  3. user        0m9.281s
  4. sys        0m0.558s
  5. [root@AnsibleTower_120 tmp]# time awk -F: '{print $1"@@"$2}' 1.txt > 2.txt

  6. real        0m12.431s
  7. user        0m9.326s
  8. sys        0m0.372s
  9. [root@AnsibleTower_120 tmp]# time sed -r 's/:/@@/g' 1.txt > 2.txt

  10. real        0m5.580s
  11. user        0m5.025s
  12. sys        0m0.331s
  13. [root@AnsibleTower_120 tmp]# time sed -r 's/:/@@/g' 1.txt > 2.txt

  14. real        0m6.859s
  15. user        0m4.910s
  16. sys        0m0.385s
復(fù)制代碼

論壇徽章:
0
10 [報(bào)告]
發(fā)表于 2018-03-23 00:23 |只看該作者
提示: 作者被禁止或刪除 內(nèi)容自動(dòng)屏蔽
您需要登錄后才可以回帖 登錄 | 注冊(cè)

本版積分規(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ū)
中國(guó)互聯(lián)網(wǎng)協(xié)會(huì)會(huì)員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過(guò)ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請(qǐng)注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP