github.com/apache/beam/sdks/v2@v2.48.2/python/apache_beam/testing/benchmarks/nexmark/queries/query1.py (about) 1 # 2 # Licensed to the Apache Software Foundation (ASF) under one or more 3 # contributor license agreements. See the NOTICE file distributed with 4 # this work for additional information regarding copyright ownership. 5 # The ASF licenses this file to You under the Apache License, Version 2.0 6 # (the "License"); you may not use this file except in compliance with 7 # the License. You may obtain a copy of the License at 8 # 9 # http://www.apache.org/licenses/LICENSE-2.0 10 # 11 # Unless required by applicable law or agreed to in writing, software 12 # distributed under the License is distributed on an "AS IS" BASIS, 13 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14 # See the License for the specific language governing permissions and 15 # limitations under the License. 16 # 17 18 """Nexmark Query 1: Convert bid prices from dollars to euros. 19 20 The Nexmark suite is a series of queries (streaming pipelines) performed 21 on a simulation of auction events. 22 23 This query converts bid prices from dollars to euros. 24 It illustrates a simple map. 25 """ 26 # pytype: skip-file 27 28 import apache_beam as beam 29 from apache_beam.testing.benchmarks.nexmark.models import nexmark_model 30 from apache_beam.testing.benchmarks.nexmark.queries import nexmark_query_util 31 32 USD_TO_EURO = 0.89 33 34 35 def load(events, metadata=None, pipeline_options=None): 36 return ( 37 events 38 | nexmark_query_util.JustBids() 39 | 'ConvertToEuro' >> beam.Map( 40 lambda bid: nexmark_model.Bid( 41 bid.auction, 42 bid.bidder, 43 bid.price * USD_TO_EURO, 44 bid.date_time, 45 bid.extra)))