Apache Beam/Dataflow: 在转换之间传递属性
创始人
2024-09-03 14:01:23
0

在 Apache Beam/Dataflow 中,在转换之间传递属性可以使用 ParDo 转换中的 withSideInputs 方法。下面是一个示例代码:

import apache_beam as beam

class AddAttributeFn(beam.DoFn):
    def __init__(self, attribute_value):
        self.attribute_value = attribute_value

    def process(self, element, *args, **kwargs):
        # 在输出元素中添加属性
        yield beam.pvalue.TaggedOutput('output', (element, self.attribute_value))

def main():
    with beam.Pipeline() as pipeline:
        input_data = pipeline | beam.Create([1, 2, 3, 4, 5])

        # 创建一个具有属性的 PCollection
        attribute_value = 10
        attribute_pcoll = pipeline | beam.Create([attribute_value])

        # 使用 withSideInputs 方法传递属性
        output_data = input_data | beam.ParDo(AddAttributeFn(), attribute_pcoll)

        # 获取输出 PCollection
        output_pcoll = output_data['output']

        # 打印输出元素和属性
        output_pcoll | beam.Map(print)

if __name__ == '__main__':
    main()

在上面的示例中,AddAttributeFn 类是一个 ParDo 转换,用于在每个输入元素上添加属性值。attribute_pcoll 是一个包含属性值的 PCollection。withSideInputs 方法将 attribute_pcoll 作为附加输入传递给 AddAttributeFn 转换。在 AddAttributeFnprocess 方法中,我们可以访问属性值并将其添加到输出元素中。

这样,我们就可以在 Apache Beam/Dataflow 中在转换之间传递属性。

相关内容

热门资讯

一分钟了解!德扑圈透视,wep... 一分钟了解!德扑圈透视,wepoker插件下载(分享透视开挂辅助挂)是一款可以让一直输的玩家,快速成...
今日公布!pokerworld... 今日公布!pokerworld修改器,wepoker数据分析(必备透视开挂辅助神器)是一款可以让一直...
玩家必看科普!hhpoker德... 玩家必看科普!hhpoker德州挂真的有,werplan可以透视(解密透视开挂辅助工具);1、选手技...
科普攻略!有人wepoker,... 科普攻略!有人wepoker,约局吧德州真的存在透视(系统透视开挂辅助插件)是一款可以让一直输的玩家...
揭秘关于!wepoker透视方... 揭秘关于!wepoker透视方法,pokemmo手机版修改器(线上透视开挂辅助插件)是一款可以让一直...
2分钟细说!拱趴大菠萝开挂方法... 2分钟细说!拱趴大菠萝开挂方法,hhpoker是真的假的(科技透视开挂辅助工具);运拱趴大菠萝开挂方...
指导大家!hhpoker有透视... 指导大家!hhpoker有透视挂的,wepoker的辅助器(安装透视开挂辅助挂);指导大家!hhpo...
如何分辨真伪!wepoker可... 您好,wepoker可以买辅助这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很...
详细说明!pokerworld... 详细说明!pokerworld辅助器,有哪些免费的wpk透视挂码(方法透视开挂辅助脚本)是一款可以让...
必备辅助推荐!拱趴大菠萝有挂,... 必备辅助推荐!拱趴大菠萝有挂,wepoker透视版下载(插件透视开挂辅助器)是一款可以让一直输的玩家...