# The `sqlite-xsv` Python package `sqlite-xsv` is also distributed on PyPi as a Python package, for use in Python applications. It works well with the builtin [`sqlite3`](https://docs.python.org/3/library/sqlite3.html) Python module. ``` pip install sqlite-xsv ``` ## Usage The `sqlite-xsv` python package exports two functions: `loadable_path()`, which returns the full path to the loadable extension, and `load(conn)`, which loads the `sqlite-xsv` extension into the given [sqlite3 Connection object](https://docs.python.org/3/library/sqlite3.html#connection-objects). ```python import sqlite_xsv print(sqlite_xsv.loadable_path()) # '/.../venv/lib/python3.9/site-packages/sqlite_xsv/xsv0' import sqlite3 conn = sqlite3.connect(':memory:') sqlite_xsv.load(conn) conn.execute('select xsv_version(), xsv()').fetchone() # ('v0.1.0', '01gr7gwc5aq22ycea6j8kxq4s9') ``` See [the full API Reference](#api-reference) for the Python API, and [`docs.md`](../../docs.md) for documentation on the `sqlite-xsv` SQL API. See [`datasette-sqlite-xsv`](../datasette_sqlite_xsv/) for a Datasette plugin that is a light wrapper around the `sqlite-xsv` Python package. ## Compatibility Currently the `sqlite-xsv` Python package is only distributed on PyPi as pre-build wheels, it's not possible to install from the source distribution. This is because the underlying `sqlite-xsv` extension requires a lot of build dependencies like `make`, `cc`, and `cargo`. If you get a `unsupported platform` error when pip installing `sqlite-xsv`, you'll have to build the `sqlite-xsv` manually and load in the dynamic library manually. ## API Reference

loadable_path()

Returns the full path to the locally-install `sqlite-xsv` extension, without the filename. This can be directly passed to [`sqlite3.Connection.load_extension()`](https://docs.python.org/3/library/sqlite3.html#sqlite3.Connection.load_extension), but the [`sqlite_xsv.load()`](#load) function is preferred. ```python import sqlite_xsv print(sqlite_xsv.loadable_path()) # '/.../venv/lib/python3.9/site-packages/sqlite_xsv/xsv0' ``` > Note: this extension path doesn't include the file extension (`.dylib`, `.so`, `.dll`). This is because [SQLite will infer the correct extension](https://www.sqlite.org/loadext.html#loading_an_extension).

load(connection)

Loads the `sqlite-xsv` extension on the given [`sqlite3.Connection`](https://docs.python.org/3/library/sqlite3.html#sqlite3.Connection) object, calling [`Connection.load_extension()`](https://docs.python.org/3/library/sqlite3.html#sqlite3.Connection.load_extension). ```python import sqlite_xsv import sqlite3 conn = sqlite3.connect(':memory:') conn.enable_load_extension(True) sqlite_xsv.load(conn) conn.enable_load_extension(False) conn.execute('select xsv_version(), xsv()').fetchone() # ('v0.1.0', '01gr7gwc5aq22ycea6j8kxq4s9') ```