github.com/apache/beam/sdks/v2@v2.48.2/python/apache_beam/examples/snippets/transforms/aggregation/min.py (about) 1 # coding=utf-8 2 # 3 # Licensed to the Apache Software Foundation (ASF) under one or more 4 # contributor license agreements. See the NOTICE file distributed with 5 # this work for additional information regarding copyright ownership. 6 # The ASF licenses this file to You under the Apache License, Version 2.0 7 # (the "License"); you may not use this file except in compliance with 8 # the License. You may obtain a copy of the License at 9 # 10 # http://www.apache.org/licenses/LICENSE-2.0 11 # 12 # Unless required by applicable law or agreed to in writing, software 13 # distributed under the License is distributed on an "AS IS" BASIS, 14 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 15 # See the License for the specific language governing permissions and 16 # limitations under the License. 17 # 18 19 20 def min_globally(test=None): 21 # [START min_globally] 22 import apache_beam as beam 23 24 with beam.Pipeline() as pipeline: 25 min_element = ( 26 pipeline 27 | 'Create numbers' >> beam.Create([3, 4, 1, 2]) 28 | 'Get min value' >> 29 beam.CombineGlobally(lambda elements: min(elements or [-1])) 30 | beam.Map(print)) 31 # [END min_globally] 32 if test: 33 test(min_element) 34 35 36 def min_per_key(test=None): 37 # [START min_per_key] 38 import apache_beam as beam 39 40 with beam.Pipeline() as pipeline: 41 elements_with_min_value_per_key = ( 42 pipeline 43 | 'Create produce' >> beam.Create([ 44 ('🥕', 3), 45 ('🥕', 2), 46 ('🍆', 1), 47 ('🍅', 4), 48 ('🍅', 5), 49 ('🍅', 3), 50 ]) 51 | 'Get min value per key' >> beam.CombinePerKey(min) 52 | beam.Map(print)) 53 # [END min_per_key] 54 if test: 55 test(elements_with_min_value_per_key)