map阶段
# -*- coding: utf-8 -*- import sys for line in sys.stdin: line = line.strip() words = line.split() for word in words: print("%s\t%s" % (word, 1))
reduce阶段
# -*- coding: utf-8 -*- import sys current_word = None current_count = 0 word = None for line in sys.stdin: word, count = line.split('\t', 1) try: count = int(count) except ValueError: continue if current_word == word: current_count += count else: if current_word: print ('%s\t%s' % (current_word, current_count)) current_word = word current_count = count if current_word == word: print('%s\t%s' % (current_word, current_count))
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。