AWSGlue作业使用create_dynamic_frame.from_catalog无法访问使用分区投影配置的表中的数据。
创始人
2024-09-25 18:02:53
0

出现该问题的原因是AWS Glue作业使用create_dynamic_frame.from_catalog时无法正确解析表中的分区投影信息,因此无法访问表中的数据。

为了解决这个问题,可以使用create_dynamic_frame.from_options方法来手动指定分区信息,而不是使用create_dynamic_frame.from_catalog方法。具体示例代码如下:

import boto3 import sys from awsglue.transforms import * from awsglue.utils import getResolvedOptions from awsglue.dynamicframe import DynamicFrame from pyspark.context import SparkContext from pyspark.sql.context import SQLContext from pyspark.sql.types import * from awsglue.context import GlueContext

args = getResolvedOptions(sys.argv, ['JOB_NAME']) sc = SparkContext() glueContext = GlueContext(sc) spark = glueContext.spark_session job = Job(glueContext) job.init(args['JOB_NAME'], args)

s3 = boto3.client('s3') tableName = "sample_table"

Get the list of partitions for the table

response = s3.list_objects_v2(Bucket='my_bucket', Prefix='my_prefix/'+tableName+'/') partitions = [] for item in response['Contents']: partitions.append(item['Key'][len('my_prefix/'+tableName+'/'):])

Create a dictionary of partition names and values

values = {} for partition in partitions: values[partition.split("=")[0]] = partition.split("=")[1]

Create a dynamic frame using the specified partition values

dynamic_frame = glueContext.create_dynamic_frame.from_options( connection_type="s3", connection_options={ "path": "s3://my_bucket/my_prefix/sample_table/", "partitionKeys": list(values.keys()) }, format="csv", format_options={ "header": True, "inferSchema": True } )

Do some transformations or analysis on the dynamic frame

...

job.commit()

相关内容

热门资讯

专业讨论!wepoke能赢嘛,... 专业讨论!wepoke能赢嘛,德州免费辅助神器app,科技教程(从前有挂)1、在德州免费辅助神器ap...
分辨真假!gg扑克有辅助吗,w... 分辨真假!gg扑克有辅助吗,wpk透视辅助,wepoke教程(往昔真的是有挂)1、构建自己的微扑克辅...
每日必看!微扑克发牌有问题吗,... 您好,aapoker辅助这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家...
实测交流!线上德州辅助工具有哪... 实测交流!线上德州辅助工具有哪些,wpk提高胜率,高科技教程(切实真的是有挂)1)wpk提高胜率辅助...
最新技巧!wepoke辅助技巧... 最新技巧!wepoke辅助技巧,wpk提高胜率,透牌教程(起初存在有挂)1、很好的工具软件,可以解锁...
重大推荐!德州alphax辅助... 重大推荐!德州alphax辅助,wepoke真的有挂,切实教程(原先是真的有挂)1、超多福利:超高返...
玩家实测!扑克世界app辅助,... 玩家实测!扑克世界app辅助,wepoke辅助机器人,详细教程(都是真的是有挂)是一款可以让一直输的...
科技介绍!wepoke辅助有挂... 科技介绍!wepoke辅助有挂吗,微扑克ai辅助工具,可靠技巧(好像存在有挂)1.微扑克ai辅助工具...
玩家必备科普!菠萝德州辅助神器... 玩家必备科普!菠萝德州辅助神器,wpk透视辅助测试,介绍教程(先前真的有挂)1、很好的工具软件,可以...
玩家交流!wpk机器人代打,微... 玩家交流!wpk机器人代打,微扑克游戏辅助器,透明挂教程(总是真的有挂);是一款可以让一直输的玩家,...