婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > shell兩個文件去重的多種姿勢

shell兩個文件去重的多種姿勢

熱門標簽:測繪地圖標注名稱 德陽400電話申請 天津電話外呼系統排名 怎么在百度地圖標注公司的位置 百度地圖標注直線距離 外呼電話系統怎么操作 鶴崗400電話申請 智能電銷機器人有用嗎 商機地圖標注

前言

大家都知道shell在文本處理上確有極大優勢,比如多文本合并、去重等,但是最近遇到了一個難搞的問題,即兩個大數據量文件去重。下面來看看詳細的介紹吧。

要求 

有txt文件A.txt和B.txt。

其中A為關鍵詞和搜索量,以逗號分隔,約90萬行。

B為關鍵詞,約400萬行。

需要從A中找出與B重復的關鍵詞。

我試了N種姿勢,但結果都不盡人意,最奇怪的是有些方法對小數據量的測試文件有用,一旦用在A與B上就會失敗,真叫人百思不得其解。

姿勢一:

awk -F, '{print $1}' A >keywords.txt
cat keywords.txt B.txt | sort | uniq -d
 
#先從A.txt種取出關鍵詞,然后與B.txt一起打開,用sort排序,uniq -d 取出重復的行

姿勢二:

awk -F, '{print $1}' A >keywords.txt
#照例先取出關鍵詞
 
comm -1 -2 keywords.txt B.txt
#利用comm命令,顯示兩個文件都存在的行

姿勢三:

awk -F, '{print $1}' A >keywords.txt
for i in `cat keywords.txt`
do
  A=`egrep -c "^$i$" B.txt`
  if [ $A != 0 ]
  then
    echo $i >>重復關鍵詞.txt
  fi
done
 
#這種姿勢就稍微復雜點
#首先取出關鍵詞,然后利用for循環逐個去B.txt里面匹配(注意正則寫法^$i$),如果匹配到的結果數不為0,說明這個關鍵詞是重復的,然后輸出
#這種方法的優點是穩妥,缺點是效率太TM低了,90萬個詞逐一與400萬詞匹配,shell默認又沒有多線程,耗時太長。

姿勢四:

awk -F, '{print $1}' A >keywords.txt
cat keywords.txt B.txt | awk '!a[$1]++'
 
#這個方法的原理其實我不太懂,awk命令實在太強大太高深了,但是這種方法又簡潔又快速

其實還有一種grep -vgrep -f 的方法,但是我沒有試過,所以不在這里列出了。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。

您可能感興趣的文章:
  • 判斷文件是否存在的shell腳本代碼
  • Shell逐行讀取文件的4種方法
  • shell去掉文件中空行(空白行)的方法詳解
  • shell腳本中執行時提示“沒有那個文件或目錄”的解決辦法
  • shell按行讀取文件的3種方法
  • Shell腳本統計文件行數的8種方法
  • Shell獲取文件的文件名和擴展名的例子
  • Shell中調用、引用、包含另一個腳本文件的三種方法
  • shell判斷文件,目錄是否存在或者具有權限的代碼
  • shell中刪除文件中重復行的方法

標簽:百色 鎮江 武漢 滁州 優質小號 六盤水 自貢 丹東

巨人網絡通訊聲明:本文標題《shell兩個文件去重的多種姿勢》,本文關鍵詞  shell,兩個,文件,去,重的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《shell兩個文件去重的多種姿勢》相關的同類信息!
  • 本頁收集關于shell兩個文件去重的多種姿勢的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 新竹县| 汨罗市| 西平县| 荆州市| 台山市| 潞西市| 永靖县| 介休市| 榆社县| 阳东县| 涞源县| 呼伦贝尔市| 子洲县| 阳新县| 平武县| 开封县| 连江县| 金塔县| 石狮市| 老河口市| 平山县| 关岭| 金川县| SHOW| 耿马| 荥阳市| 南郑县| 留坝县| 寿宁县| 贞丰县| 安陆市| 海原县| 响水县| 琼结县| 武汉市| 义马市| 泰安市| 齐河县| 方正县| 大庆市| 宝坻区|