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

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

Chinaunix

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

awk/sed 查找對照表問題 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2010-04-01 14:28 |只看該作者 |倒序?yàn)g覽
有兩個(gè)文件1.txt、2.txt
1.txt:
1
23
033
04567

2.txt
1 first
23 second
033 thrid
04567 fourth

其中2是對照表。請問如何用awk/sed,將1.txt內(nèi)容替換為
first
second
thrid
fourth

普通的shell語句會寫(使用while讀每一行,在2.txt中查找、替換,生成新文件),但是如果1.txt和2.txt都有上千萬行的話,效率很低。有沒有比較高效的方法來解決這個(gè)問題呢?

論壇徽章:
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
2 [報(bào)告]
發(fā)表于 2010-04-01 14:33 |只看該作者
回復(fù) 1# yhou31


    hash.
    追求高效就用perl吧。

論壇徽章:
0
3 [報(bào)告]
發(fā)表于 2010-04-01 14:49 |只看該作者
回復(fù) 1# yhou31


    把2的數(shù)字去掉也行吧?
sed 's/[^ ]* //'

論壇徽章:
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
4 [報(bào)告]
發(fā)表于 2010-04-01 14:49 |只看該作者
  1. awk 'NR==FNR{a[$1]=$2;next}{print a[$1]}' 2.txt 1.txt
復(fù)制代碼

論壇徽章:
0
5 [報(bào)告]
發(fā)表于 2010-04-01 14:52 |只看該作者
回復(fù) 3# iori809


    你這個(gè)太水了。。。
   把2的數(shù)字去掉 ,你還不如直接去2的第2列 > 1.txt 豈不是更爽?
   LZ的意思很明顯是舉例子,文件肯定不會就是這樣2行,或者順序不一定就是這樣。。。

論壇徽章:
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
6 [報(bào)告]
發(fā)表于 2010-04-01 14:53 |只看該作者
本帖最后由 blackold 于 2010-04-01 15:10 編輯
  1. grep -Fwf 1.txt 2.txt|cut -d\  -f2
復(fù)制代碼
不好意思,這個(gè)結(jié)果不符合要求。

論壇徽章:
0
7 [報(bào)告]
發(fā)表于 2010-04-01 14:54 |只看該作者
回復(fù) 5# 709101040516


    哈哈~發(fā)完以后我就后悔了~哎剛說完別人自己就出丑了~以后要小心謹(jǐn)慎了~尤其是你在線的時(shí)候

論壇徽章:
0
8 [報(bào)告]
發(fā)表于 2010-04-01 15:03 |只看該作者
回復(fù) 4# blackold


    強(qiáng)!能解釋下嗎?

論壇徽章:
0
9 [報(bào)告]
發(fā)表于 2010-04-01 15:09 |只看該作者
awk 'NR==FNR{array[$1]=$2}NR>FNR && $1 in array{print array[$1]}'
呵呵 從新寫個(gè)

論壇徽章:
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
10 [報(bào)告]
發(fā)表于 2010-04-01 15:10 |只看該作者
回復(fù) 8# yhou31


    awk基礎(chǔ)。看一下貼子吧。
您需要登錄后才可以回帖 登錄 | 注冊

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

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP