The package can be installed via pip:
pip install git+https://github.com/Breakthrough-Energy/fs-azureblob
Or by cloning the repository and installing directly:
git clone https://github.com/Breakthrough-Energy/fs-azureblob
cd fs-azureblob
pip install .
Either approach will also install the core fs
package if it's not already installed.
Use fs.open_fs
to open a filesystem with an azure blob
FS URL:
import fs
my_fs = fs.open_fs("azblob://[account_name]:[account_key]@[container]")
The BlobFS
class can also be instantiated directly
from fs.azblob import BlobFS
my_fs = BlobFS(account_name, container, account_key)
using the following arguments:
account_name
: the name of the storage accountcontainer
: the blob containeraccount_key
: optional, but required for write operations or depending on the storage account access policies
Since blob storage uses a flat namespace (directories don't really exist), we create a
placeholder file to represent them, always named .fs_azblob
. This is an empty blob
which is created for new directories, removed when a directory is removed, and omitted
from listdir
results, so should be transparent to users. To use this package on a new
blob storage container, nothing needs to be done. For usage on an existing container,
one should create this structure using the azure portal, sdk, or preferred tool, to
ensure this package will function as expected.
Additionally, this package is intended to operate on "block blobs". Other blob types include page blobs and append blobs. The package has not been tested on these types.
- fs, the core PyFilesystem2 library