Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
azure-datalake-store
Advanced tools
.. image:: https://travis-ci.org/Azure/azure-data-lake-store-python.svg?branch=dev :target: https://travis-ci.org/Azure/azure-data-lake-store-python .. image:: https://coveralls.io/repos/github/Azure/azure-data-lake-store-python/badge.svg?branch=master :target: https://coveralls.io/github/Azure/azure-data-lake-store-python?branch=master
This project is the Python filesystem library for Azure Data Lake Store.
To install from source instead of pip (for local testing and development):
.. code-block:: bash
> pip install -r dev_requirements.txt
> python setup.py develop
To play with the code, here is a starting point:
.. code-block:: python
from azure.datalake.store import core, lib, multithread
token = lib.auth(tenant_id, username, password)
adl = core.AzureDLFileSystem(token, store_name=store_name)
# typical operations
adl.ls('')
adl.ls('tmp/', detail=True)
adl.ls('tmp/', detail=True, invalidate_cache=True)
adl.cat('littlefile')
adl.head('gdelt20150827.csv')
# file-like object
with adl.open('gdelt20150827.csv', blocksize=2**20) as f:
print(f.readline())
print(f.readline())
print(f.readline())
# could have passed f to any function requiring a file object:
# pandas.read_csv(f)
with adl.open('anewfile', 'wb') as f:
# data is written on flush/close, or when buffer is bigger than
# blocksize
f.write(b'important data')
adl.du('anewfile')
# recursively download the whole directory tree with 5 threads and
# 16MB chunks
multithread.ADLDownloader(adl, "", 'my_temp_dir', 5, 2**24)
Progress can be tracked using a callback function in the form track(current, total)
When passed, this will keep track of transferred bytes and be called on each complete chunk.
Here's an example using the Azure CLI progress controller as the progress_callback
:
.. code-block:: python
from cli.core.application import APPLICATION
def _update_progress(current, total):
hook = APPLICATION.get_progress_controller(det=True)
hook.add(message='Alive', value=current, total_val=total)
if total == current:
hook.end()
...
ADLUploader(client, destination_path, source_path, thread_count, overwrite=overwrite,
chunksize=chunk_size,
buffersize=buffer_size,
blocksize=block_size,
progress_callback=_update_progress)
This will output a progress bar to the stdout:
.. code-block:: bash
Alive[######################### ] 40.0881%
Finished[#############################################################] 100.0000%
To interact with the API at a higher-level, you can use the provided command-line interface in "samples/cli.py". You will need to set the appropriate environment variables
:code:azure_username
:code:azure_password
:code:azure_data_lake_store_name
:code:azure_subscription_id
:code:azure_resource_group_name
:code:azure_service_principal
:code:azure_service_principal_secret
to connect to the Azure Data Lake Store. Optionally, you may need to define :code:azure_tenant_id
or :code:azure_data_lake_store_url_suffix
.
Below is a simple sample, with more details beyond.
.. code-block:: bash
python samples\cli.py ls -l
Execute the program without arguments to access documentation.
To start the CLI in interactive mode, run "python samples/cli.py" and then type "help" to see all available commands (similiar to Unix utilities):
.. code-block:: bash
> python samples/cli.py
azure> help
Documented commands (type help <topic>):
========================================
cat chmod close du get help ls mv quit rmdir touch
chgrp chown df exists head info mkdir put rm tail
azure>
While still in interactive mode, you can run "ls -l" to list the entries in the home directory ("help ls" will show the command's usage details). If you're not familiar with the Unix/Linux "ls" command, the columns represent 1) permissions, 2) file owner, 3) file group, 4) file size, 5-7) file's modification time, and 8) file name.
.. code-block:: bash
> python samples/cli.py
azure> ls -l
drwxrwx--- 0123abcd 0123abcd 0 Aug 02 12:44 azure1
-rwxrwx--- 0123abcd 0123abcd 1048576 Jul 25 18:33 abc.csv
-r-xr-xr-x 0123abcd 0123abcd 36 Jul 22 18:32 xyz.csv
drwxrwx--- 0123abcd 0123abcd 0 Aug 03 13:46 tmp
azure> ls -l --human-readable
drwxrwx--- 0123abcd 0123abcd 0B Aug 02 12:44 azure1
-rwxrwx--- 0123abcd 0123abcd 1M Jul 25 18:33 abc.csv
-r-xr-xr-x 0123abcd 0123abcd 36B Jul 22 18:32 xyz.csv
drwxrwx--- 0123abcd 0123abcd 0B Aug 03 13:46 tmp
azure>
To download a remote file, run "get remote-file [local-file]". The second argument, "local-file", is optional. If not provided, the local file will be named after the remote file minus the directory path.
.. code-block:: bash
> python samples/cli.py
azure> ls -l
drwxrwx--- 0123abcd 0123abcd 0 Aug 02 12:44 azure1
-rwxrwx--- 0123abcd 0123abcd 1048576 Jul 25 18:33 abc.csv
-r-xr-xr-x 0123abcd 0123abcd 36 Jul 22 18:32 xyz.csv
drwxrwx--- 0123abcd 0123abcd 0 Aug 03 13:46 tmp
azure> get xyz.csv
2016-08-04 18:57:48,603 - ADLFS - DEBUG - Creating empty file xyz.csv
2016-08-04 18:57:48,604 - ADLFS - DEBUG - Fetch: xyz.csv, 0-36
2016-08-04 18:57:49,726 - ADLFS - DEBUG - Downloaded to xyz.csv, byte offset 0
2016-08-04 18:57:49,734 - ADLFS - DEBUG - File downloaded (xyz.csv -> xyz.csv)
azure>
It is also possible to run in command-line mode, allowing any available command to be executed separately without remaining in the interpreter.
For example, listing the entries in the home directory:
.. code-block:: bash
> python samples/cli.py ls -l
drwxrwx--- 0123abcd 0123abcd 0 Aug 02 12:44 azure1
-rwxrwx--- 0123abcd 0123abcd 1048576 Jul 25 18:33 abc.csv
-r-xr-xr-x 0123abcd 0123abcd 36 Jul 22 18:32 xyz.csv
drwxrwx--- 0123abcd 0123abcd 0 Aug 03 13:46 tmp
>
Also, downloading a remote file:
.. code-block:: bash
> python samples/cli.py get xyz.csv
2016-08-04 18:57:48,603 - ADLFS - DEBUG - Creating empty file xyz.csv
2016-08-04 18:57:48,604 - ADLFS - DEBUG - Fetch: xyz.csv, 0-36
2016-08-04 18:57:49,726 - ADLFS - DEBUG - Downloaded to xyz.csv, byte offset 0
2016-08-04 18:57:49,734 - ADLFS - DEBUG - File downloaded (xyz.csv -> xyz.csv)
>
For detailed documentation about our test framework, please visit the
tests folder <https://github.com/Azure/azure-data-lake-store-python/tree/master/tests>
__.
Be sure to check out the Microsoft Azure Developer Forums on Stack Overflow <http://go.microsoft.com/fwlink/?LinkId=234489>
__
if you have trouble with the provided code. Most questions are tagged azure and python <https://stackoverflow.com/questions/tagged/azure+python>
__.
If you would like to become an active contributor to this project please
follow the instructions provided in Microsoft Azure Projects Contribution Guidelines <http://azure.github.io/guidelines/>
.
Furthermore, check out GUIDANCE.md <https://github.com/Azure/azure-data-lake-store-python/blob/master/GUIDANCE.md>
for specific information related to this project.
If you encounter any bugs with the library please file an issue in the
Issues <https://github.com/Azure/azure-data-lake-store-python/issues>
__
section of the project.
This project has adopted the Microsoft Open Source Code of Conduct <https://opensource.microsoft.com/codeofconduct/>
.
For more information see the Code of Conduct FAQ <https://opensource.microsoft.com/codeofconduct/faq/>
or contact
opencode@microsoft.com <mailto:opencode@microsoft.com>
__ with any additional questions or comments.
.. :changelog:
0.0.53 (2023-04-11) +++++++++++++++++++
0.0.52 (2020-11-25) +++++++++++++++++++
0.0.51 (2020-10-15) +++++++++++++++++++
0.0.50 (2020-09-10) +++++++++++++++++++
0.0.49 (2020-08-05) +++++++++++++++++++
0.0.48 (2019-10-18) +++++++++++++++++++
0.0.47 (2019-08-14) +++++++++++++++++++
0.0.46 (2019-06-25) +++++++++++++++++++
0.0.45 (2019-05-10) +++++++++++++++++++
0.0.44 (2019-03-05) +++++++++++++++++++
0.0.43 (2019-03-01) +++++++++++++++++++
0.0.42 (2019-02-26) +++++++++++++++++++
0.0.41 (2019-01-31) +++++++++++++++++++
0.0.40 (2019-01-08) +++++++++++++++++++
0.0.39 (2018-11-14) +++++++++++++++++++
0.0.38 (2018-11-12) +++++++++++++++++++
0.0.37 (2018-11-02) +++++++++++++++++++
0.0.36 (2018-10-31) +++++++++++++++++++
0.0.35 (2018-10-29) +++++++++++++++++++
0.0.34 (2018-10-15) +++++++++++++++++++
0.0.32 (2018-10-04) +++++++++++++++++++
0.0.31 (2018-09-10) +++++++++++++++++++
0.0.30 (2018-08-28) +++++++++++++++++++
0.0.29 (2018-08-22) +++++++++++++++++++
0.0.28 (2018-08-20) +++++++++++++++++++
0.0.27 (2018-08-08) +++++++++++++++++++
0.0.26 (2018-08-03) +++++++++++++++++++
0.0.25 (2018-07-26) +++++++++++++++++++
0.0.24 (2018-07-16) +++++++++++++++++++
0.0.23 (2018-07-11) +++++++++++++++++++
0.0.22 (2018-06-02) +++++++++++++++++++
0.0.21 (2018-06-01) +++++++++++++++++++
0.0.20 (2018-05-25) +++++++++++++++++++
transfer
future done_callback
#177.inprogress
suffix. This suffix is removed when the download completes successfully.ls
calls. It is now set to always call the service instead of the cache by default.GitHub issue 625 <https://github.com/pyca/pyopenssl/issues/625>
Fix for downloader to ensure there is access to the source path before creating destination files
Fix for credential objects to inherit from msrest.authentication for more universal authentication support
Add support for the following:
set_expiry: allows for setting expiration on files
ACL management:
Remove unsupported and unused "TRUNCATE" operation.
Added API-Version support with a default of the latest api version (2016-11-01)
FAQs
Azure Data Lake Store Filesystem Client Library for Python
We found that azure-datalake-store demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.