用于构建mapreduce作业原型的python库

mockr的Python项目详细描述


Documentation Status

模拟机

mockr是一个python库,用于在教育环境中编写mapreduce作业。它的用途是 概念教学工具。

mockr提供了一个接口,用于在本地定义和运行mapreduce。只需定义map和reduce函数, 输入数据并调用run函数。一切都是按顺序和本地运行的。

安装

pip install mockr

文档

这里有完整的文档https://mockr.readthedocs.io/

流作业

streamingjob类,该类期望输入为字符的字节流。数据块由 换行符(“\n”)字符。每一行都被发送到一个单独的地图工作者。

原生python序列作业

pythonjob类期望输入为collections.abc.sequence类型对象,例如python list。python作业提供两个 执行方法:

  • 序列被分成块,每个块被发送到单独的映射工作器
  • 列表中的每个项目都单独发送给一个专用的地图工作者

熊猫工作

pandasjob类希望输入为pandas数据帧。数据帧的行平均分为块和 每个块都被发送到一个单独的map worker

示例用法

import re
from mockr import run_stream_job

WORD_RE = re.compile(r"[\w']+")

def map_fn(chunk):
    # yield each word in the line
    for word in WORD_RE.findall(chunk):
        yield (word.lower(), 1)

def reduce_fn(key, values):
    yield (key, sum(values))

input_str = "Hello!\nThis is a sample string.\nIt is very simple.\nGoodbye!"

results = run_stream_job(input_str, map_fn, reduce_fn)

print(results)

输出:

[('hello', 1), ('this', 1), ('is', 2), ('a', 1), ('sample', 1), ('string', 1), ('it', 1), ('very', 1), ('simple', 1), ('goodbye', 1)]

欢迎加入QQ群-->: 979659372 Python中文网_新手群

推荐PyPI第三方库


热门话题
java允许具有不同父类的类扩展类,而无需多重继承   java如何创建动态化的JScrollPane w/JPanel作为客户端?   java如何组织和命名包   在Java中读取属性文件   java无法解释的Android意图行为   在Java中动态执行多个BPEL文件的部署   ssl Java 6 SNI(服务器名称指示)?   java我们可以使用Robot框架自动化web和移动应用程序来执行并行执行   java for star pettern的循环   java为什么BinaryReader在线程中,从netty读取错误的数据包?   在java中将华氏度转换为摄氏度   使用Spark和java处理空值和引号编写CSV文件   Java中已排序日期到块的列表   visual studio代码VSCode Java不是linting或自动完成局部变量,而是自动完成Java快捷方式,如“sysout”