Azure Databricks:ImportError:没有名为azure.storage.blob的模块

时间:2019-01-09 11:53:33

标签: azure azure-databricks

使用示例代码example.py(Azure文档提供:快速入门:使用Python上传,下载和列出Blob)时,出现以下导入错误。

文档链接:https://github.com/Azure-Samples/storage-blobs-python-quickstart/blob/master/example.py

ImportError: No module named azure.storage.blob
---------------------------------------------------------------------------
ImportError                               Traceback (most recent call last)
 in ()
      1 import os, uuid, sys
----> 2 from azure.storage.blob import BlockBlobService, PublicAccess
      3 

请帮助我解决此问题。

由于它在Azure云上的笔记本中运行,因此不涉及python安装。因此,请不要建议我使用其他版本的python。

import os, uuid, sys
from azure.storage.blob import BlockBlobService, PublicAccess

def run_sample():
    try:
        # Create the BlockBlockService that is used to call the Blob service for the storage account
        block_blob_service = BlockBlobService(account_name='accountname', account_key='accountkey')

        # Create a container called 'quickstartblobs'.
        container_name ='quickstartblobs'
        block_blob_service.create_container(container_name)

        # Set the permission so the blobs are public.
        block_blob_service.set_container_acl(container_name, public_access=PublicAccess.Container)

        # Create a file in Documents to test the upload and download.
        local_path=os.path.expanduser("~/Documents")
        local_file_name ="QuickStart_" + str(uuid.uuid4()) + ".txt"
        full_path_to_file =os.path.join(local_path, local_file_name)

        # Write text to the file.
        file = open(full_path_to_file,  'w')
        file.write("Hello, World!")
        file.close()

        print("Temp file = " + full_path_to_file)
        print("\nUploading to Blob storage as blob" + local_file_name)

        # Upload the created file, use local_file_name for the blob name
        block_blob_service.create_blob_from_path(container_name, local_file_name, full_path_to_file)

        # List the blobs in the container
        print("\nList blobs in the container")
        generator = block_blob_service.list_blobs(container_name)
        for blob in generator:
            print("\t Blob name: " + blob.name)

        # Download the blob(s).
        # Add '_DOWNLOADED' as prefix to '.txt' so you can see both files in Documents.
        full_path_to_file2 = os.path.join(local_path, str.replace(local_file_name ,'.txt', '_DOWNLOADED.txt'))
        print("\nDownloading blob to " + full_path_to_file2)
        block_blob_service.get_blob_to_path(container_name, local_file_name, full_path_to_file2)

        sys.stdout.write("Sample finished running. When you hit <any key>, the sample will be deleted and the sample "
                         "application will exit.")
        sys.stdout.flush()
        input()

        # Clean up resources. This includes the container and the temp files
        block_blob_service.delete_container(container_name)
        os.remove(full_path_to_file)
        os.remove(full_path_to_file2)
    except Exception as e:
        print(e)

if __name__ == '__main__':
    run_sample()

2 个答案:

答案 0 :(得分:1)

据我所知,您可以在 NoteBook 单元格中使用 pip intall,例如:

pip install azure-storage-file

答案 1 :(得分:0)