title | description | services | documentationcenter | author | manager | editor | ms.assetid | ms.service | ms.workload | ms.tgt_pltfrm | ms.devlang | ms.topic | ms.date | ms.author |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
How to use Azure File storage from Python | Microsoft Docs |
Learn how to use the Azure File storage from Python to upload, list, download, and delete files. |
storage |
python |
robinsh |
timlt |
tysonn |
297f3a14-6b3a-48b0-9da4-db5907827fb5 |
storage |
storage |
na |
python |
article |
12/08/2016 |
robinsh |
[!INCLUDE storage-selector-file-include]
[!INCLUDE storage-try-azure-tools-files]
This article will show you how to perform common scenarios using File storage. The samples are written in Python and use the Microsoft Azure Storage SDK for Python. The scenarios covered include uploading, listing, downloading, and deleting files.
[!INCLUDE storage-file-concepts-include]
[!INCLUDE storage-create-account-include]
The FileService object lets you work with shares, directories and files. The following code creates a FileService object. Add the following near the top of any Python file in which you wish to programmatically access Azure Storage.
from azure.storage.file import FileService
The following code creates a FileService object using the storage account name and account key. Replace 'myaccount' and 'mykey' with your account name and key.
file_service = **FileService** (account_name='myaccount', account_key='mykey')
In the following code example, you can use a FileService object to create the share if it doesn't exist.
file_service.create_share('myshare')
An Azure File Storage Share contains at the very least, a root directory where files can reside. In this section, you'll learn how to upload a file from local storage onto the root directory of a share.
To create a file and upload data, use the create_file_from_path, create_file_from_stream, create_file_from_bytes or create_file_from_text methods. They are high-level methods that perform the necessary chunking when the size of the data exceeds 64 MB.
create_file_from_path uploads the contents of a file from the specified path, and create_file_from_stream uploads the contents from an already opened file/stream. create_file_from_bytes uploads an array of bytes, and create_file_from_text uploads the specified text value using the specified encoding (defaults to UTF-8).
The following example uploads the contents of the sunset.png file into the myfile file.
from azure.storage.file import ContentSettings
file_service.create_file_from_path(
'myshare',
None, # We want to create this blob in the root directory, so we specify None for the directory_name
'myfile',
'sunset.png',
content_settings=ContentSettings(content_type='image/png'))
You can also organize storage by putting files inside sub-directories instead of having all of them in the root directory. The Azure file storage service allows you to create as many directories as your account will allow. The code below will create a sub-directory named sampledir under the root directory.
file_service.create_directory('myshare', 'sampledir')
To list the files and directories in a share, use the list_directories_and_files method. This method returns a generator. The following code outputs the name of each file and directory in a share to the console.
generator = file_service.list_directories_and_files('myshare')
for file_or_dir in generator:
print(file_or_dir.name)
To download data from a file, use get_file_to_path, get_file_to_stream, get_file_to_bytes, or get_file_to_text. They are high-level methods that perform the necessary chunking when the size of the data exceeds 64 MB.
The following example demonstrates using get_file_to_path to download the contents of the myfile file and store it to the out-sunset.png file.
file_service.get_file_to_path('myshare', None, 'myfile', 'out-sunset.png')
Finally, to delete a file, call delete_file.
file_service.delete_file('myshare', None, 'myfile')
Now that you've learned the basics of File storage, follow these links to learn more.