Skip to main content

Python3 interface to rasdaman

Project description

rasdapy is a client API for rasdaman that enables building and executing rasql queries within python.

Requirements

Installation

  1. Make sure you have installed pip3 (e.g. sudo apt install python-pip3)

  2. Install rasdapy3 with pip3 install rasdapy3

  1. Note that if you do not have setuptools, numpy, grpcio, and protobuf installed, they will be downloaded as dependencies.

Usage

A full client with a similar interface as the C++ rasql client is available that demonstrates how to use rasdapy to send queries to rasdaman and handle the results. Below the most important details for using rasdapy are listed.

Import rasdapy core API

>>> from rasdapy.db_connector import DBConnector
>>> from rasdapy.query_executor import QueryExecutor

Connect to rasdaman

The DBConnector maintains the connection to rasdaman. In order to connect it is necessary to specify the host and port on which rasmgr is running, as well as valid rasdaman username and password.

>>> db_connector = DBConnector("localhost", 7001, "rasadmin", "rasadmin")

Create the query executor

QueryExcutor is the interface through which rasql queries (create, insert, update, delete, etc.) are executed.

>>> query_executor = QueryExecutor(db_connector)

Open the connection to rasdaman

>>> db_connector.open()

Execute sample queries

The query below returns a list of all the collections available in rasdaman.

>>> colls = query_executor.execute_read("select c from RAS_COLLECTIONNAMES as c")
>>> print(colls)

Calculate the average of all values in collection mr2.

>>> result = query_executor.execute_read("select avg_cells(c) from mr2 as c")
>>> type(result)

Depending on the query the result will have a different type (e.g. scalar value, interval, array). Each data type is wrapped in a corresponding class.

Select a particular subset of each array in collection mr2. This query will return raw array data that can be converted to a Numpy ndarray.

>>> result = query_executor.execute_read("select m[0:10 ,0:10] from mr2 as m")
>>> numpy_array = result.to_array()

Encode array subset to PNG format and write the result to a file.

>>> result = query_executor.execute_read("select encode(m[0:10 ,0:10], \"png\") from mr2 as m")
>>> with open("/tmp/output.png", "wb") as binary_file:
>>>   binary_file.write(result.data[0])

Create a rasdaman collection. Note that you should be connected with a user that has write permission; by default this is rasadmin/rasadmin in rasdaman, but this can be managed by the administrator.

>>> query_executor.execute_write("create collection test_rasdapy GreySet")

Insert data from a PNG image into the collection. Similarly you need to have write permissions for this operation.

>>> query_executor.execute_write("insert into test_rasdapy values decode($1)", "mr_1.png")

Alternatively, you can import data from a raw binary file; in this case it is necessary to specify the spatial domain and array type.

>>> query_executor.execute_update_from_file("insert into test_rasdapy values $1",
                                            "raw_array.bin", "[0:100]", "GreyString")

Further example queries and a general guide for rasql can be found in the rasdaman documentation.

Close the connection to rasdaman

>>> db_connector.close()

Best practices:

It is recommended to follow this template in order to avoid problems with leaked transactions:

from rasdapy.db_connector import DBConnector
from rasdapy.query_executor import QueryExecutor

db_connector = DBConnector("localhost", 7001, "rasadmin", "rasadmin")
query_executor = QueryExecutor(db_connector)

db_connector.open()

try:
    query_executor.execute_read("...")
    query_executor.execute_write("...")
    # ... more Python code
finally:
    db_connector.close()

Contributors

  • Bang Pham Huu

  • Siddharth Shukla

  • Dimitar Misev

  • Jean-François Lecomte

  • Dragi Kamov

Thanks also to

  • Alex Mircea Dumitru

  • Vlad Merticariu

  • George Merticariu

  • Alex Toader

  • Peter Baumann

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

rasdapy3-1.1.0.tar.gz (68.4 kB view details)

Uploaded Source

Built Distribution

rasdapy3-1.1.0-py2.py3-none-any.whl (82.1 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file rasdapy3-1.1.0.tar.gz.

File metadata

  • Download URL: rasdapy3-1.1.0.tar.gz
  • Upload date:
  • Size: 68.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for rasdapy3-1.1.0.tar.gz
Algorithm Hash digest
SHA256 90cc70f3c5741a9ccf94d5b42f6cd069f290555c9fe34e3a0b278a05e924d36e
MD5 9ea2760750df354d7d4147e86f111799
BLAKE2b-256 ef5ae79ad7d19216d637bf3e403f1c34fe55e16f1bf0a3f60a59e2e83cde9869

See more details on using hashes here.

File details

Details for the file rasdapy3-1.1.0-py2.py3-none-any.whl.

File metadata

  • Download URL: rasdapy3-1.1.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 82.1 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.6

File hashes

Hashes for rasdapy3-1.1.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 5c4719646e0794c29488c80e61c15e2ab2d6a74f034baeab49f0bd29fcbec7f9
MD5 90388d0e6727eb07fdfb3f486604889c
BLAKE2b-256 7c8e848d2b8c14352d62a176d4820a594ee064008d01255233fdbc106b543c8f

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page