Skip to content

Commit

Permalink
docs: add ibis.connect to top_level API docs
Browse files Browse the repository at this point in the history
  • Loading branch information
cpcloud committed Sep 9, 2023
1 parent d0c6476 commit 0d197e8
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 5 deletions.
2 changes: 2 additions & 0 deletions docs/_quarto.yml
Original file line number Diff line number Diff line change
Expand Up @@ -202,6 +202,8 @@ quartodoc:
dynamic: true
- name: coalesce
package: ibis.expr.api
- name: connect
package: ibis.backends.base
- name: cumulative_window
dynamic: true
- name: date
Expand Down
32 changes: 27 additions & 5 deletions ibis/backends/base/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -1167,6 +1167,21 @@ def _get_backend_names() -> frozenset[str]:
def connect(resource: Path | str, **kwargs: Any) -> BaseBackend:
"""Connect to `resource`, inferring the backend automatically.
The general pattern for `ibis.connect` is
```python
ibis.connect("backend://connection-parameters")
```
With many backends that looks like
```python
ibis.connect("backend://user:password@host:port/database")
```
See the connection syntax for each backend for details about URL connection
requirements.
Parameters
----------
resource
Expand All @@ -1176,15 +1191,22 @@ def connect(resource: Path | str, **kwargs: Any) -> BaseBackend:
Examples
--------
Connect to an in-memory duckdb database:
Connect to an in-memory DuckDB database:
>>> con = ibis.connect("duckdb://")
Connect to an on-disk sqlite database:
>>> con = ibis.connect("sqlite://relative/path/to/data.db")
Connect to an on-disk SQLite database:
>>> con = ibis.connect("sqlite://relative.db")
>>> con = ibis.connect("sqlite:///absolute/path/to/data.db")
Connect to a postgres server:
>>> con = ibis.connect("postgres://user:password@hostname:5432")
Connect to a PostgreSQL server:
>>> con = ibis.connect("postgres://user:password@hostname:5432") # quartodoc: +SKIP # doctest: +SKIP
Connect to BigQuery:
>>> con = ibis.connect("bigquery://my-project/my-dataset") # quartodoc: +SKIP # doctest: +SKIP
"""
url = resource = str(resource)

Expand Down

0 comments on commit 0d197e8

Please sign in to comment.