ShareFileClient Class  
A client to interact with a specific file, although that file may not yet exist.
For more optional configuration, please click here.
Constructor
ShareFileClient(account_url: str, share_name: str, file_path: str, snapshot: str | Dict[str, Any] | None = None, credential: str | Dict[str, str] | AzureNamedKeyCredential | AzureSasCredential | TokenCredential | None = None, *, token_intent: Literal['backup'] | None = None, **kwargs: Any)Parameters
| Name | Description | 
|---|---|
| account_url 
				Required
			 | The URI to the storage account. In order to create a client given the full URI to the file, use the from_file_url classmethod. | 
| share_name 
				Required
			 | The name of the share for the file. | 
| file_path 
				Required
			 | The file path to the file with which to interact. If specified, this value will override a file value specified in the file URL. | 
| snapshot | An optional file snapshot on which to operate. This can be the snapshot ID string or the response returned from create_snapshot. Default value: None | 
| credential | The credentials with which to authenticate. This is optional if the account URL already has a SAS token. The value can be a SAS token string, an instance of a AzureSasCredential or AzureNamedKeyCredential from azure.core.credentials, an account shared access key, or an instance of a TokenCredentials class from azure.identity. If the resource URI already contains a SAS token, this will be ignored in favor of an explicit credential 
 Default value: None | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| token_intent | 
				Literal['backup']
		 Required when using TokenCredential for authentication and ignored for other forms of authentication. Specifies the intent for all requests when using TokenCredential authentication. Possible values are: backup - Specifies requests are intended for backup/admin type operations, meaning that all file/directory ACLs are bypassed and full permissions are granted. User must also have required RBAC permission. Default value: None | 
| allow_trailing_dot | If true, the trailing dot will not be trimmed from the target URI. | 
| allow_source_trailing_dot | If true, the trailing dot will not be trimmed from the source URI. | 
| api_version | The Storage API version to use for requests. Default value is the most recent service version that is compatible with the current SDK. Setting to an older version may result in reduced feature compatibility. New in version 12.1.0. | 
| secondary_hostname | The hostname of the secondary endpoint. | 
| max_range_size | The maximum range size used for a file upload. Defaults to  | 
| audience | The audience to use when requesting tokens for Azure Active Directory authentication. Only has an effect when credential is of type TokenCredential. The value could be https://storage.azure.com/ (default) or https://<account>.file.core.windows.net. | 
Methods
| abort_copy | Abort an ongoing copy operation. This will leave a destination file with zero length and full metadata. This will raise an error if the copy operation has already ended. | 
| acquire_lease | Requests a new lease. If the file does not have an active lease, the File Service creates a lease on the blob and returns a new lease. | 
| clear_range | Clears the specified range and releases the space used in storage for that range. | 
| close | This method is to close the sockets opened by the client. It need not be used when using with a context manager. | 
| close_all_handles | Close any open file handles. This operation will block until the service has closed all open handles. | 
| close_handle | Close an open file handle. | 
| create_file | Creates a new file. Note that it only initializes the file with no content. | 
| create_hardlink | NFS only. Creates a hard link to the file specified by path. | 
| create_symlink | NFS only. Creates a symbolic link to the specified file. | 
| delete_file | Marks the specified file for deletion. The file is later deleted during garbage collection. | 
| download_file | Downloads a file to the StorageStreamDownloader. The readall() method must be used to read all the content or readinto() must be used to download the file into a stream. Using chunks() returns an iterator which allows the user to iterate over the content in chunks. | 
| exists | Returns True if the file exists and returns False otherwise. | 
| from_connection_string | Create ShareFileClient from a Connection String. | 
| from_file_url | A client to interact with a specific file, although that file may not yet exist. | 
| get_file_properties | Returns all user-defined metadata, standard HTTP properties, and system properties for the file. | 
| get_ranges | Returns the list of valid page ranges for a file or snapshot of a file. | 
| get_ranges_diff | Returns the list of valid page ranges for a file or snapshot of a file. New in version 12.6.0. | 
| get_symlink | NFS only. Gets the symbolic link for the file client. | 
| list_handles | Lists handles for file. | 
| rename_file | Rename the source file. | 
| resize_file | Resizes a file to the specified size. | 
| set_file_metadata | Sets user-defined metadata for the specified file as one or more name-value pairs. Each call to this operation replaces all existing metadata attached to the file. To remove all metadata from the file, call this operation with no metadata dict. | 
| set_http_headers | Sets HTTP headers on the file. | 
| start_copy_from_url | Initiates the copying of data from a source URL into the file referenced by the client. The status of this copy operation can be found using the get_properties method. | 
| upload_file | Uploads a new file. | 
| upload_range | Upload a range of bytes to a file. | 
| upload_range_from_url | Writes the bytes from one Azure File endpoint into the specified range of another Azure File endpoint. | 
abort_copy
Abort an ongoing copy operation.
This will leave a destination file with zero length and full metadata. This will raise an error if the copy operation has already ended.
abort_copy(copy_id: str | FileProperties, **kwargs: Any) -> NoneParameters
| Name | Description | 
|---|---|
| copy_id 
				Required
			 | The copy operation to abort. This can be either an ID, or an instance of FileProperties. | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| lease | Required if the file has an active lease. Value can be a ShareLeaseClient object or the lease ID as a string. New in version 12.1.0. | 
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
Returns
| Type | Description | 
|---|---|
acquire_lease
Requests a new lease.
If the file does not have an active lease, the File Service creates a lease on the blob and returns a new lease.
acquire_lease(lease_id: str | None = None, **kwargs: Any) -> ShareLeaseClientParameters
| Name | Description | 
|---|---|
| lease_id | Proposed lease ID, in a GUID string format. The File Service returns 400 (Invalid request) if the proposed lease ID is not in the correct format. Default value: None | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
Returns
| Type | Description | 
|---|---|
| A ShareLeaseClient object. | 
Examples
Acquiring a lease on a file.
   source_file.create_file(1024)
   lease = source_file.acquire_lease()
   source_file.upload_file(b'hello world', lease=lease)
   lease.release()
clear_range
Clears the specified range and releases the space used in storage for that range.
clear_range(offset: int, length: int, **kwargs: Any) -> Dict[str, Any]Parameters
| Name | Description | 
|---|---|
| offset 
				Required
			 | Start of byte range to use for clearing a section of the file. The range can be up to 4 MB in size. | 
| length 
				Required
			 | Number of bytes to use for clearing a section of the file. The range can be up to 4 MB in size. | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| lease | Required if the file has an active lease. Value can be a ShareLeaseClient object or the lease ID as a string. New in version 12.1.0. | 
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
Returns
| Type | Description | 
|---|---|
| File-updated property dict (Etag and last modified). | 
close
This method is to close the sockets opened by the client. It need not be used when using with a context manager.
close() -> Noneclose_all_handles
Close any open file handles.
This operation will block until the service has closed all open handles.
close_all_handles(**kwargs: Any) -> Dict[str, int]Keyword-Only Parameters
| Name | Description | 
|---|---|
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
Returns
| Type | Description | 
|---|---|
| The number of handles closed (this may be 0 if the specified handle was not found) and the number of handles failed to close in a dict. | 
close_handle
Close an open file handle.
close_handle(handle: str | Handle, **kwargs: Any) -> Dict[str, int]Parameters
| Name | Description | 
|---|---|
| handle 
				Required
			 | A specific handle to close. | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
Returns
| Type | Description | 
|---|---|
| The number of handles closed (this may be 0 if the specified handle was not found) and the number of handles failed to close in a dict. | 
create_file
Creates a new file.
Note that it only initializes the file with no content.
create_file(size: int, file_attributes: str | NTFSAttributes | None = None, file_creation_time: str | datetime | None = None, file_last_write_time: str | datetime | None = None, file_permission: str | None = None, permission_key: str | None = None, **kwargs: Any) -> Dict[str, Any]Parameters
| Name | Description | 
|---|---|
| size 
				Required
			 | Specifies the maximum size for the file, up to 1 TB. | 
| file_attributes | The file system attributes for files and directories. If not set, the default value would be "None" and the attributes will be set to "Archive". Here is an example for when the var type is str: 'Temporary|Archive'. file_attributes value is not case sensitive. Default value: None | 
| file_creation_time | Creation time for the file Default value: Now. Default value: None | 
| file_last_write_time | Last write time for the file Default value: Now. Default value: None | 
| file_permission | If specified the permission (security descriptor) shall be set for the directory/file. This header can be used if Permission size is <= 8KB, else x-ms-file-permission-key header shall be used. Default value: Inherit. If SDDL is specified as input, it must have owner, group and dacl. Note: Only one of the x-ms-file-permission or x-ms-file-permission-key should be specified. Default value: None | 
| permission_key | Key of the permission to be set for the directory/file. Note: Only one of the x-ms-file-permission or x-ms-file-permission-key should be specified. Default value: None | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| file_permission_format | 
				Literal['sddl', 'binary']
		 Specifies the format in which the permission is returned. If not specified, SDDL will be the default. | 
| file_change_time | Change time for the file. If not specified, change time will be set to the current date/time. New in version 12.8.0: This parameter was introduced in API version '2021-06-08'. | 
| content_settings | ContentSettings object used to set file properties. Used to set content type, encoding, language, disposition, md5, and cache control. | 
| metadata | Name-value pairs associated with the file as metadata. | 
| lease | Required if the file has an active lease. Value can be a ShareLeaseClient object or the lease ID as a string. New in version 12.1.0. | 
| owner | NFS only. The owner of the file. | 
| group | NFS only. The owning group of the file. | 
| file_mode | NFS only. The file mode of the file. | 
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
Returns
| Type | Description | 
|---|---|
| File-updated property dict (Etag and last modified). | 
Examples
Create a file.
   # Create and allocate bytes for the file (no content added yet)
   my_allocated_file.create_file(size=100)
create_hardlink
NFS only. Creates a hard link to the file specified by path.
create_hardlink(target: str, *, lease: ShareLeaseClient | str | None = None, timeout: int | None = None, **kwargs: Any) -> Dict[str, Any]Parameters
| Name | Description | 
|---|---|
| target 
				Required
			 | Specifies the path of the target file to which the link will be created, up to 2 KiB in length. It should be the full path of the target starting from the root. The target file must be in the same share and the same storage account. | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| lease | Required if the file has an active lease. Value can be a ShareLeaseClient object or the lease ID as a string. Default value: None | 
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. Default value: None | 
Returns
| Type | Description | 
|---|---|
| File-updated property dict (ETag and last modified). | 
create_symlink
NFS only. Creates a symbolic link to the specified file.
create_symlink(target: str, *, metadata: Dict[str, str] | None = None, file_creation_time: str | datetime | None = None, file_last_write_time: str | datetime | None = None, owner: str | None = None, group: str | None = None, lease: ShareLeaseClient | str | None = None, timeout: int | None = None, **kwargs: Any) -> Dict[str, Any]Parameters
| Name | Description | 
|---|---|
| target 
				Required
			 | Specifies the file path the symbolic link will point to. The file path can be either relative or absolute. | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| metadata | Name-value pairs associated with the file as metadata. Default value: None | 
| file_creation_time | Creation time for the file. Default value: None | 
| file_last_write_time | Last write time for the file. Default value: None | 
| owner | The owner of the file. Default value: None | 
| group | The owning group of the file. Default value: None | 
| lease | Required if the file has an active lease. Value can be a ShareLeaseClient object or the lease ID as a string. Default value: None | 
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timeouts see here. Default value: None | 
Returns
| Type | Description | 
|---|---|
| File-updated property dict (ETag and last modified). | 
delete_file
Marks the specified file for deletion. The file is later deleted during garbage collection.
delete_file(**kwargs: Any) -> NoneKeyword-Only Parameters
| Name | Description | 
|---|---|
| lease | Required if the file has an active lease. Value can be a ShareLeaseClient object or the lease ID as a string. New in version 12.1.0. | 
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
Returns
| Type | Description | 
|---|---|
Examples
Delete a file.
   my_file.delete_file()
download_file
Downloads a file to the StorageStreamDownloader. The readall() method must be used to read all the content or readinto() must be used to download the file into a stream. Using chunks() returns an iterator which allows the user to iterate over the content in chunks.
download_file(offset: int | None = None, length: int | None = None, **kwargs: Any) -> StorageStreamDownloaderParameters
| Name | Description | 
|---|---|
| offset | Start of byte range to use for downloading a section of the file. Must be set if length is provided. Default value: None | 
| length | Number of bytes to read from the stream. This is optional, but should be supplied for optimal performance. Default value: None | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| max_concurrency | Maximum number of parallel connections to use when transferring the file in chunks. This option does not affect the underlying connection pool, and may require a separate configuration of the connection pool. | 
| validate_content | If true, calculates an MD5 hash for each chunk of the file. The storage service checks the hash of the content that has arrived with the hash that was sent. This is primarily valuable for detecting bitflips on the wire if using http instead of https as https (the default) will already validate. Note that this MD5 hash is not stored with the file. Also note that if enabled, the memory-efficient upload algorithm will not be used, because computing the MD5 hash requires buffering entire blocks, and doing so defeats the purpose of the memory-efficient algorithm. | 
| lease | Required if the file has an active lease. Value can be a ShareLeaseClient object or the lease ID as a string. New in version 12.1.0. | 
| progress_hook | A callback to track the progress of a long running download. The signature is function(current: int, total: int) where current is the number of bytes transferred so far, and total is the total size of the download. | 
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
Returns
| Type | Description | 
|---|---|
| 
							<xref:azure.storage.fileshare.StorageStreamDownloader>
						 | A streaming object (StorageStreamDownloader) | 
Examples
Download a file.
   with open(DEST_FILE, "wb") as data:
       stream = my_file.download_file()
       data.write(stream.readall())
exists
Returns True if the file exists and returns False otherwise.
exists(**kwargs: Any) -> boolKeyword-Only Parameters
| Name | Description | 
|---|---|
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
Returns
| Type | Description | 
|---|---|
| True if the file exists, False otherwise. | 
from_connection_string
Create ShareFileClient from a Connection String.
from_connection_string(conn_str: str, share_name: str, file_path: str, snapshot: str | Dict[str, Any] | None = None, credential: str | Dict[str, str] | AzureNamedKeyCredential | AzureSasCredential | TokenCredential | None = None, **kwargs: Any) -> SelfParameters
| Name | Description | 
|---|---|
| conn_str 
				Required
			 | A connection string to an Azure Storage account. | 
| share_name 
				Required
			 | The name of the share. | 
| file_path 
				Required
			 | The file path. | 
| snapshot | An optional file snapshot on which to operate. This can be the snapshot ID string or the response returned from create_snapshot. Default value: None | 
| credential | The credentials with which to authenticate. This is optional if the account URL already has a SAS token. The value can be a SAS token string, an instance of a AzureSasCredential or AzureNamedKeyCredential from azure.core.credentials, an account shared access key, or an instance of a TokenCredentials class from azure.identity. If the resource URI already contains a SAS token, this will be ignored in favor of an explicit credential 
 Default value: None | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| audience | The audience to use when requesting tokens for Azure Active Directory authentication. Only has an effect when credential is of type TokenCredential. The value could be https://storage.azure.com/ (default) or https://<account>.file.core.windows.net. | 
Returns
| Type | Description | 
|---|---|
| A File client. | 
Examples
Creates the file client with connection string.
   from azure.storage.fileshare import ShareFileClient
   file = ShareFileClient.from_connection_string(
       self.connection_string,
       share_name="helloworld2",
       file_path="myfile")
from_file_url
A client to interact with a specific file, although that file may not yet exist.
from_file_url(file_url: str, snapshot: str | Dict[str, Any] | None = None, credential: str | Dict[str, str] | AzureNamedKeyCredential | AzureSasCredential | TokenCredential | None = None, **kwargs: Any) -> SelfParameters
| Name | Description | 
|---|---|
| file_url 
				Required
			 | The full URI to the file. | 
| snapshot | An optional file snapshot on which to operate. This can be the snapshot ID string or the response returned from create_snapshot. Default value: None | 
| credential | The credentials with which to authenticate. This is optional if the account URL already has a SAS token. The value can be a SAS token string, an instance of a AzureSasCredential or AzureNamedKeyCredential from azure.core.credentials, an account shared access key, or an instance of a TokenCredentials class from azure.identity. If the resource URI already contains a SAS token, this will be ignored in favor of an explicit credential 
 Default value: None | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| audience | The audience to use when requesting tokens for Azure Active Directory authentication. Only has an effect when credential is of type TokenCredential. The value could be https://storage.azure.com/ (default) or https://<account>.file.core.windows.net. | 
Returns
| Type | Description | 
|---|---|
| A File client. | 
get_file_properties
Returns all user-defined metadata, standard HTTP properties, and system properties for the file.
get_file_properties(**kwargs: Any) -> FilePropertiesKeyword-Only Parameters
| Name | Description | 
|---|---|
| lease | Required if the file has an active lease. Value can be a ShareLeaseClient object or the lease ID as a string. New in version 12.1.0. | 
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
Returns
| Type | Description | 
|---|---|
| FileProperties | 
get_ranges
Returns the list of valid page ranges for a file or snapshot of a file.
get_ranges(offset: int | None = None, length: int | None = None, **kwargs: Any) -> List[Dict[str, int]]Parameters
| Name | Description | 
|---|---|
| offset | Specifies the start offset of bytes over which to get ranges. Default value: None | 
| length | Number of bytes to use over which to get ranges. Default value: None | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| lease | Required if the file has an active lease. Value can be a ShareLeaseClient object or the lease ID as a string. New in version 12.1.0. | 
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
Returns
| Type | Description | 
|---|---|
| A list of valid ranges. | 
get_ranges_diff
Returns the list of valid page ranges for a file or snapshot of a file.
New in version 12.6.0.
get_ranges_diff(previous_sharesnapshot: str | Dict[str, Any], offset: int | None = None, length: int | None = None, *, include_renames: bool | None = None, **kwargs: Any) -> Tuple[List[Dict[str, int]], List[Dict[str, int]]]Parameters
| Name | Description | 
|---|---|
| offset | Specifies the start offset of bytes over which to get ranges. Default value: None | 
| length | Number of bytes to use over which to get ranges. Default value: None | 
| previous_sharesnapshot 
				Required
			 | The snapshot diff parameter that contains an opaque DateTime value that specifies a previous file snapshot to be compared against a more recent snapshot or the current file. | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| include_renames | Only valid if previous_sharesnapshot parameter is provided. Specifies whether the changed ranges for a file that has been renamed or moved between the target snapshot (or live file) and the previous snapshot should be listed. If set to True, the valid changed ranges for the file will be returned. If set to False, the operation will result in a 409 (Conflict) response. Default value: None | 
| lease | Required if the file has an active lease. Value can be a ShareLeaseClient object or the lease ID as a string. | 
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
Returns
| Type | Description | 
|---|---|
| A tuple of two lists of file ranges as dictionaries with 'start' and 'end' keys. The first element are filled file ranges, the 2nd element is cleared file ranges. | 
get_symlink
NFS only. Gets the symbolic link for the file client.
get_symlink(*, timeout: int | None = None, **kwargs: Any) -> Dict[str, Any]Keyword-Only Parameters
| Name | Description | 
|---|---|
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timeouts see here. Default value: None | 
Returns
| Type | Description | 
|---|---|
| File-updated property dict (ETag and last modified). | 
list_handles
Lists handles for file.
list_handles(**kwargs: Any) -> ItemPaged[Handle]Keyword-Only Parameters
| Name | Description | 
|---|---|
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
Returns
| Type | Description | 
|---|---|
| An auto-paging iterable of Handle | 
rename_file
Rename the source file.
rename_file(new_name: str, **kwargs: Any) -> ShareFileClientParameters
| Name | Description | 
|---|---|
| new_name 
				Required
			 | The new file name. | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
| overwrite | A boolean value for if the destination file already exists, whether this request will overwrite the file or not. If true, the rename will succeed and will overwrite the destination file. If not provided or if false and the destination file does exist, the request will not overwrite the destination file. If provided and the destination file doesn't exist, the rename will succeed. | 
| ignore_read_only | A boolean value that specifies whether the ReadOnly attribute on a preexisting destination file should be respected. If true, the rename will succeed, otherwise, a previous file at the destination with the ReadOnly attribute set will cause the rename to fail. | 
| file_permission | If specified the permission (security descriptor) shall be set for the file. This header can be used if Permission size is <= 8KB, else file_permission_key shall be used. If SDDL is specified as input, it must have owner, group and dacl. A value of 'preserve' can be passed to preserve source permissions. Note: Only one of the file_permission or file_permission_key should be specified. | 
| file_permission_key | Key of the permission to be set for the file. Note: Only one of the file-permission or file-permission-key should be specified. | 
| file_permission_format | 
				Literal['sddl', 'binary']
		 Specifies the format in which the permission is returned. If not specified, SDDL will be the default. | 
| file_attributes | The file system attributes for the file. | 
| file_creation_time | Creation time for the file. | 
| file_last_write_time | Last write time for the file. | 
| file_change_time | Change time for the file. If not specified, change time will be set to the current date/time. New in version 12.8.0: This parameter was introduced in API version '2021-06-08'. | 
| content_type | The Content Type of the new file. New in version 12.8.0: This parameter was introduced in API version '2021-06-08'. | 
| metadata | A name-value pair to associate with a file storage object. | 
| source_lease | Required if the source file has an active lease. Value can be a ShareLeaseClient object or the lease ID as a string. | 
| destination_lease | Required if the destination file has an active lease. Value can be a ShareLeaseClient object or the lease ID as a string. | 
Returns
| Type | Description | 
|---|---|
| The new File Client. | 
resize_file
Resizes a file to the specified size.
resize_file(size: int, **kwargs: Any) -> Dict[str, Any]Parameters
| Name | Description | 
|---|---|
| size 
				Required
			 | Size to resize file to (in bytes) | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| lease | Required if the file has an active lease. Value can be a ShareLeaseClient object or the lease ID as a string. New in version 12.1.0. | 
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
Returns
| Type | Description | 
|---|---|
| File-updated property dict (Etag and last modified). | 
set_file_metadata
Sets user-defined metadata for the specified file as one or more name-value pairs.
Each call to this operation replaces all existing metadata attached to the file. To remove all metadata from the file, call this operation with no metadata dict.
set_file_metadata(metadata: Dict[str, Any] | None = None, **kwargs: Any) -> Dict[str, Any]Parameters
| Name | Description | 
|---|---|
| metadata | Name-value pairs associated with the file as metadata. Default value: None | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| lease | Required if the file has an active lease. Value can be a ShareLeaseClient object or the lease ID as a string. New in version 12.1.0. | 
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
Returns
| Type | Description | 
|---|---|
| File-updated property dict (Etag and last modified). | 
set_http_headers
Sets HTTP headers on the file.
set_http_headers(content_settings: ContentSettings, file_attributes: str | NTFSAttributes | None = None, file_creation_time: str | datetime | None = None, file_last_write_time: str | datetime | None = None, file_permission: str | None = None, permission_key: str | None = None, **kwargs: Any) -> Dict[str, Any]Parameters
| Name | Description | 
|---|---|
| content_settings 
				Required
			 | ContentSettings object used to set file properties. Used to set content type, encoding, language, disposition, md5, and cache control. | 
| file_attributes | The file system attributes for files and directories. If not set, indicates preservation of existing values. Here is an example for when the var type is str: 'Temporary|Archive' Default value: None | 
| file_creation_time | Creation time for the file Default value: Preserve. Default value: None | 
| file_last_write_time | Last write time for the file Default value: Preserve. Default value: None | 
| file_permission | If specified the permission (security descriptor) shall be set for the directory/file. This header can be used if Permission size is <= 8KB, else x-ms-file-permission-key header shall be used. Default value: Inherit. If SDDL is specified as input, it must have owner, group and dacl. Note: Only one of the x-ms-file-permission or x-ms-file-permission-key should be specified. Default value: None | 
| permission_key | Key of the permission to be set for the directory/file. Note: Only one of the x-ms-file-permission or x-ms-file-permission-key should be specified. Default value: None | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| file_permission_format | 
				Literal['sddl', 'binary']
		 Specifies the format in which the permission is returned. If not specified, SDDL will be the default. | 
| file_change_time | Change time for the file. If not specified, change time will be set to the current date/time. New in version 12.8.0: This parameter was introduced in API version '2021-06-08'. | 
| lease | Required if the file has an active lease. Value can be a ShareLeaseClient object or the lease ID as a string. New in version 12.1.0. | 
| owner | NFS only. The owner of the file. | 
| group | NFS only. The owning group of the file. | 
| file_mode | NFS only. The file mode of the file. | 
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
Returns
| Type | Description | 
|---|---|
| File-updated property dict (Etag and last modified). | 
start_copy_from_url
Initiates the copying of data from a source URL into the file referenced by the client.
The status of this copy operation can be found using the get_properties method.
start_copy_from_url(source_url: str, **kwargs: Any) -> Dict[str, Any]Parameters
| Name | Description | 
|---|---|
| source_url 
				Required
			 | Specifies the URL of the source file. | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| file_permission | If specified the permission (security descriptor) shall be set for the directory/file. This value can be set to "source" to copy the security descriptor from the source file. Otherwise if set, this value will be used to override the source value. If not set, permission value is inherited from the parent directory of the target file. This setting can be used if Permission size is <= 8KB, otherwise permission_key shall be used. If SDDL is specified as input, it must have owner, group and dacl. Note: Only one of the file_permission or permission_key should be specified. New in version 12.1.0: This parameter was introduced in API version '2019-07-07'. | 
| permission_key | Key of the permission to be set for the directory/file. This value can be set to "source" to copy the security descriptor from the source file. Otherwise if set, this value will be used to override the source value. If not set, permission value is inherited from the parent directory of the target file. Note: Only one of the file_permission or permission_key should be specified. New in version 12.1.0: This parameter was introduced in API version '2019-07-07'. | 
| file_permission_format | 
				Literal['sddl', 'binary']
		 Specifies the format in which the permission is returned. If not specified, SDDL will be the default. | 
| file_attributes | This value can be set to "source" to copy file attributes from the source file to the target file, or to clear all attributes, it can be set to "None". Otherwise it can be set to a list of attributes to set on the target file. If this is not set, the default value is "Archive". New in version 12.1.0: This parameter was introduced in API version '2019-07-07'. | 
| file_creation_time | This value can be set to "source" to copy the creation time from the source file to the target file, or a datetime to set as creation time on the target file. This could also be a string in ISO 8601 format. If this is not set, creation time will be set to the date time value of the creation (or when it was overwritten) of the target file by copy engine. New in version 12.1.0: This parameter was introduced in API version '2019-07-07'. | 
| file_last_write_time | This value can be set to "source" to copy the last write time from the source file to the target file, or a datetime to set as the last write time on the target file. This could also be a string in ISO 8601 format. If this is not set, value will be the last write time to the file by the copy engine. New in version 12.1.0: This parameter was introduced in API version '2019-07-07'. | 
| file_change_time | Change time for the file. If not specified, change time will be set to the current date/time. New in version 12.9.0: This parameter was introduced in API version '2021-06-08'. | 
| ignore_read_only | Specifies the option to overwrite the target file if it already exists and has read-only attribute set. New in version 12.1.0: This parameter was introduced in API version '2019-07-07'. | 
| set_archive_attribute | Specifies the option to set the archive attribute on the target file. True means the archive attribute will be set on the target file despite attribute overrides or the source file state. New in version 12.1.0: This parameter was introduced in API version '2019-07-07'. | 
| metadata | Name-value pairs associated with the file as metadata. | 
| lease | Required if the file has an active lease. Value can be a ShareLeaseClient object or the lease ID as a string. New in version 12.1.0. | 
| owner | NFS only. The owner of the file. | 
| group | NFS only. The owning group of the file. | 
| file_mode | NFS only. The file mode of the file. | 
| file_mode_copy_mode | 
				Literal['source', 'override']
		 NFS only. Applicable only when the copy source is a File. Determines the copy behavior of the mode bits of the file. Possible values are: source - The mode on the destination file is copied from the source file. override - The mode on the destination file is determined via the file_mode keyword. | 
| owner_copy_mode | 
				Literal['source', 'override']
		 NFS only. Applicable only when the copy source is a File. Determines the copy behavior of the owner and group of the file. Possible values are: source - The owner and group on the destination file is copied from the source file. override - The owner and group on the destination file is determined via the owner and group keywords. | 
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
Returns
| Type | Description | 
|---|---|
| Response after data copying operation has been initiated. | 
Examples
Copy a file from a URL
   destination_file.start_copy_from_url(source_url=source_url)
upload_file
Uploads a new file.
upload_file(data: bytes | str | Iterable | IO, length: int | None = None, file_attributes: str | NTFSAttributes | None = None, file_creation_time: str | datetime | None = None, file_last_write_time: str | datetime | None = None, file_permission: str | None = None, permission_key: str | None = None, **kwargs) -> Dict[str, Any]Parameters
| Name | Description | 
|---|---|
| data 
				Required
			 | Content of the file. | 
| length | Length of the file in bytes. Specify its maximum size, up to 1 TiB. Default value: None | 
| file_attributes | The file system attributes for files and directories. If not set, the default value would be "None" and the attributes will be set to "Archive". Here is an example for when the var type is str: 'Temporary|Archive'. file_attributes value is not case sensitive. Default value: None | 
| file_creation_time | Creation time for the file Default value: Now. Default value: None | 
| file_last_write_time | Last write time for the file Default value: Now. Default value: None | 
| file_permission | If specified the permission (security descriptor) shall be set for the directory/file. This header can be used if Permission size is <= 8KB, else x-ms-file-permission-key header shall be used. Default value: Inherit. If SDDL is specified as input, it must have owner, group and dacl. Note: Only one of the x-ms-file-permission or x-ms-file-permission-key should be specified. Default value: None | 
| permission_key | Key of the permission to be set for the directory/file. Note: Only one of the x-ms-file-permission or x-ms-file-permission-key should be specified. Default value: None | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| file_change_time | Change time for the file. If not specified, change time will be set to the current date/time. New in version 12.8.0: This parameter was introduced in API version '2021-06-08'. | 
| metadata | Name-value pairs associated with the file as metadata. | 
| content_settings | ContentSettings object used to set file properties. Used to set content type, encoding, language, disposition, md5, and cache control. | 
| validate_content | If true, calculates an MD5 hash for each range of the file. The storage service checks the hash of the content that has arrived with the hash that was sent. This is primarily valuable for detecting bitflips on the wire if using http instead of https as https (the default) will already validate. Note that this MD5 hash is not stored with the file. | 
| max_concurrency | Maximum number of parallel connections to use when transferring the file in chunks. This option does not affect the underlying connection pool, and may require a separate configuration of the connection pool. | 
| lease | Required if the file has an active lease. Value can be a ShareLeaseClient object or the lease ID as a string. New in version 12.1.0. | 
| progress_hook | A callback to track the progress of a long running upload. The signature is function(current: int, total: Optional[int]) where current is the number of bytes transferred so far, and total is the size of the blob or None if the size is unknown. | 
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
| encoding | Defaults to UTF-8. | 
Returns
| Type | Description | 
|---|---|
| File-updated property dict (Etag and last modified). | 
Examples
Upload a file.
   with open(SOURCE_FILE, "rb") as source:
       my_file.upload_file(source)
upload_range
Upload a range of bytes to a file.
upload_range(data: bytes, offset: int, length: int, **kwargs: Any) -> Dict[str, Any]Parameters
| Name | Description | 
|---|---|
| data 
				Required
			 | The data to upload. | 
| offset 
				Required
			 | Start of byte range to use for uploading a section of the file. The range can be up to 4 MB in size. | 
| length 
				Required
			 | Number of bytes to use for uploading a section of the file. The range can be up to 4 MB in size. | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| validate_content | If true, calculates an MD5 hash of the page content. The storage service checks the hash of the content that has arrived with the hash that was sent. This is primarily valuable for detecting bitflips on the wire if using http instead of https as https (the default) will already validate. Note that this MD5 hash is not stored with the file. | 
| file_last_write_mode | 
				Literal["preserve", "now"]
		 If the file last write time should be preserved or overwritten. Possible values are "preserve" or "now". If not specified, file last write time will be changed to the current date/time. New in version 12.8.0: This parameter was introduced in API version '2021-06-08'. | 
| lease | Required if the file has an active lease. Value can be a ShareLeaseClient object or the lease ID as a string. New in version 12.1.0. | 
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
| encoding | Defaults to UTF-8. | 
Returns
| Type | Description | 
|---|---|
| File-updated property dict (Etag and last modified). | 
upload_range_from_url
Writes the bytes from one Azure File endpoint into the specified range of another Azure File endpoint.
upload_range_from_url(source_url: str, offset: int, length: int, source_offset: int, **kwargs: Any) -> Dict[str, Any]Parameters
| Name | Description | 
|---|---|
| offset 
				Required
			 | Start of byte range to use for updating a section of the file. The range can be up to 4 MB in size. | 
| length 
				Required
			 | Number of bytes to use for updating a section of the file. The range can be up to 4 MB in size. | 
| source_url 
				Required
			 | A URL of up to 2 KB in length that specifies an Azure file or blob. The value should be URL-encoded as it would appear in a request URI. If the source is in another account, the source must either be public or must be authenticated via a shared access signature. If the source is public, no authentication is required. Examples: https://myaccount.file.core.windows.net/myshare/mydir/myfile https://otheraccount.file.core.windows.net/myshare/mydir/myfile?sastoken | 
| source_offset 
				Required
			 | This indicates the start of the range of bytes(inclusive) that has to be taken from the copy source. The service will read the same number of bytes as the destination range (length-offset). | 
Keyword-Only Parameters
| Name | Description | 
|---|---|
| source_if_modified_since | A DateTime value. Azure expects the date value passed in to be UTC. If timezone is included, any non-UTC datetimes will be converted to UTC. If a date is passed in without timezone info, it is assumed to be UTC. Specify this conditional header to copy the blob only if the source blob has been modified since the specified date/time. | 
| source_if_unmodified_since | A DateTime value. Azure expects the date value passed in to be UTC. If timezone is included, any non-UTC datetimes will be converted to UTC. If a date is passed in without timezone info, it is assumed to be UTC. Specify this conditional header to copy the blob only if the source blob has not been modified since the specified date/time. | 
| source_etag | The source ETag value, or the wildcard character (*). Used to check if the resource has changed, and act according to the condition specified by the match_condition parameter. | 
| source_match_condition | The source match condition to use upon the etag. | 
| file_last_write_mode | 
				Literal["preserve", "now"]
		 If the file last write time should be preserved or overwritten. Possible values are "preserve" or "now". If not specified, file last write time will be changed to the current date/time. New in version 12.8.0: This parameter was introduced in API version '2021-06-08'. | 
| lease | Required if the file has an active lease. Value can be a ShareLeaseClient object or the lease ID as a string. New in version 12.1.0. | 
| timeout | Sets the server-side timeout for the operation in seconds. For more details see https://free.blessedness.top/rest/api/storageservices/setting-timeouts-for-file-service-operations. This value is not tracked or validated on the client. To configure client-side network timesouts see here. | 
| source_authorization | Authenticate as a service principal using a client secret to access a source blob. Ensure "bearer " is the prefix of the source_authorization string. | 
Returns
| Type | Description | 
|---|---|
| Result after writing to the specified range of the destination Azure File endpoint. | 
Attributes
api_version
location_mode
The location mode that the client is currently using.
By default this will be "primary". Options include "primary" and "secondary".
Returns
| Type | Description | 
|---|---|
| The current location mode. | 
primary_endpoint
primary_hostname
The hostname of the primary endpoint.
Returns
| Type | Description | 
|---|---|
| The hostname of the primary endpoint. | 
secondary_endpoint
The full secondary endpoint URL if configured.
If not available a ValueError will be raised. To explicitly specify a secondary hostname, use the optional secondary_hostname keyword argument on instantiation.
Returns
| Type | Description | 
|---|---|
| The full secondary endpoint URL. | 
Exceptions
| Type | Description | 
|---|---|
| If no secondary endpoint is configured. | 
secondary_hostname
url
The full endpoint URL to this entity, including SAS token if used.
This could be either the primary endpoint, or the secondary endpoint depending on the current location_mode.
Returns
| Type | Description | 
|---|---|
| The full endpoint URL to this entity, including SAS token if used. |