用Python寫map,reduce

用Python寫map,reduce

#!/usr/bin/env python
import sys
for line in sys.stdin:
    line= line.strip()
    words= line.split()
    for word in words:
        print'%s\t%s' % (word,1)
--map.py
#!/usr/bin/env python
 
from operator import itemgetter
import sys
word2count = {}
for line in sys.stdin:
    line = line.strip()
    word, count =line.split('\t', 1)
    try:
        count =int(count)
        word2count[word]=word2count.get(word,0)+count
    except ValueError:
        pass
sorted_word2count = sorted(word2count.items(),key=itemgetter(0))
for word,count in sorted_word2count:
    print'%s\t%s' % (word, count)

--
測試:
echo "foo fooquux labs foo bar quux" | ./mapper.py | sort | ./reducer.py
提交HADOOP集群運行:

      hadoop jar hadoop-1.2.1/contrib/streaming/hadoop-streaming-1.2.1.jar -input input -output output-streaming-python  -mapper /home/mapper.py -reducer /home/reducer.py
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容