我需要将 CSV 文件上传到 Azure 数据湖 Gen2 文件系统。我在创建 Azure 数据湖文件时尝试设置该文件的内容类型。请参阅下面的代码:from azure.storage.filedatalake import DataLakeServiceClient, ContentSettingsdef upload_file_to_directory(category, type, startdatetime, enddatetime, content): try: service_client = get_service_client() file_system_client = service_client.get_file_system_client(file_system="tag-data") category_directory_client = file_system_client.get_directory_client(category) type_directory_client = category_directory_client.get_sub_directory_client(type) year_directory_client = type_directory_client.get_sub_directory_client(startdatetime.strftime("%Y")) month_directory_client = year_directory_client.get_sub_directory_client(startdatetime.strftime("%m")) day_directory_client = month_directory_client.get_sub_directory_client(startdatetime.strftime("%d")) metadata = {"uploadedby": "Casper Alant"} content_settings = ContentSettings(content_type = "text/csv") file_name = startdatetime.strftime("%Y%m%d%H%M%S") + "-" + enddatetime.strftime("%Y%m%d%H%M%S") + ".csv" file_client = day_directory_client.get_file_client(file_name) file_client.create_file(content_settings=content_settings, metadata=metadata) file_client.append_data(data=content, offset=0, length=len(content)) file_client.flush_data(len(content)) except Exception as e: print(e)该文件是使用内容创建的,“uploadedby”元数据已正确设置,但我无法让它设置内容类型。我一直在关注这里的官方文档。我似乎找不到很多关于使用此SDK的资源。
1 回答

拉莫斯之舞
TA贡献1820条经验 获得超10个赞
如果使用的是 azure-storage-file-datalake 12.0.0b7,则可以在该方法中进行设置。content-typeflush_data
#your other code
content_settings = ContentSettings(content_type = "text/csv")
file_client.flush_data(len(content),content_settings=content_settings)
添加回答
举报
0/150
提交
取消