MCPcopy Index your code
hub / github.com/simonw/datasette

github.com/simonw/datasette @1.0a35 sqlite

repository ↗ · DeepWiki ↗ · release 1.0a35 ↗
5,218 symbols 20,401 edges 171 files 513 documented · 10% 1 cross-repo links
README

Datasette

PyPI Changelog Python 3.x Tests Documentation Status License docker: datasette discord

An open source multi-tool for exploring and publishing data

Datasette is a tool for exploring and publishing data. It helps people take data of any shape or size and publish that as an interactive, explorable website and accompanying API.

Datasette is aimed at data journalists, museum curators, archivists, local governments, scientists, researchers and anyone else who has data that they wish to share with the world.

Explore a demo, watch a video about the project or try it out on GitHub Codespaces.

  • datasette.io is the official project website
  • Latest Datasette News
  • Comprehensive documentation: https://docs.datasette.io/
  • Examples: https://datasette.io/examples
  • Live demo of current main branch: https://latest.datasette.io/
  • Questions, feedback or want to talk about the project? Join our Discord

Want to stay up-to-date with the project? Subscribe to the Datasette newsletter for tips, tricks and news on what's new in the Datasette ecosystem.

Installation

If you are on a Mac, Homebrew is the easiest way to install Datasette:

brew install datasette

You can also install it using pip or pipx:

pip install datasette

Datasette requires Python 3.8 or higher. We also have detailed installation instructions covering other options such as Docker.

Basic usage

datasette serve path/to/database.db

This will start a web server on port 8001 - visit http://localhost:8001/ to access the web interface.

serve is the default subcommand, you can omit it if you like.

Use Chrome on OS X? You can run datasette against your browser history like so:

 datasette ~/Library/Application\ Support/Google/Chrome/Default/History --nolock

Now visiting http://localhost:8001/History/downloads will show you a web interface to browse your downloads data:

Downloads table rendered by datasette

metadata.json

If you want to include licensing and source information in the generated datasette website you can do so using a JSON file that looks something like this:

{
    "title": "Five Thirty Eight",
    "license": "CC Attribution 4.0 License",
    "license_url": "http://creativecommons.org/licenses/by/4.0/",
    "source": "fivethirtyeight/data on GitHub",
    "source_url": "https://github.com/fivethirtyeight/data"
}

Save this in metadata.json and run Datasette like so:

datasette serve fivethirtyeight.db -m metadata.json

The license and source information will be displayed on the index page and in the footer. They will also be included in the JSON produced by the API.

datasette publish

If you have Heroku or Google Cloud Run configured, Datasette can deploy one or more SQLite databases to the internet with a single command:

datasette publish heroku database.db

Or:

datasette publish cloudrun database.db

This will create a docker image containing both the datasette application and the specified SQLite database files. It will then deploy that image to Heroku or Cloud Run and give you a URL to access the resulting website and API.

See Publishing data in the documentation for more details.

Datasette Lite

Datasette Lite is Datasette packaged using WebAssembly so that it runs entirely in your browser, no Python web application server required. Read more about that in the Datasette Lite documentation.

Core symbols most depended-on inside this repo

json
called by 458
datasette/utils/asgi.py
append
called by 320
datasette/utils/multipart.py
execute_write
called by 268
datasette/database.py
invoke_startup
called by 210
datasette/app.py
join
called by 208
datasette/static/cm-editor-6.0.1.bundle.js
allowed
called by 193
datasette/app.py
get
called by 192
datasette/views/row.py
find
called by 170
datasette/static/cm-editor-6.0.1.bundle.js

Shape

Function 2,493
Method 2,000
Class 673
Route 52

Languages

Python57%
TypeScript43%

Modules by API surface

datasette/static/cm-editor-6.0.1.bundle.js1,853 symbols
datasette/static/edit-tools.js232 symbols
datasette/app.py146 symbols
tests/test_plugins.py133 symbols
datasette/utils/__init__.py114 symbols
tests/test_queries.py87 symbols
datasette/views/table_extras.py83 symbols
tests/test_table_html.py75 symbols
datasette/views/table_create_alter.py75 symbols
tests/test_html.py74 symbols
datasette/database.py73 symbols
tests/test_table_api.py70 symbols

Used by 1 indexed graphs manifest dependencies, hub-wide

Dependencies from manifests, versioned

@codemirror/lang-sql6.3.3 · 1×
@rollup/plugin-node-resolve15.0.1 · 1×
@rollup/plugin-terser0.1.0 · 1×
codemirror6.0.1 · 1×
prettier3.0.0 · 1×
rollup3.30.0 · 1×
Jinja22.10.3 · 1×
PyYAML5.3 · 1×
aiofiles0.4 · 1×
asgiref3.2.10 · 1×
asyncinject0.7 · 1×
click7.1.1 · 1×

Datastores touched

fixturesDatabase · 1 repos
_memoryDatabase · 1 repos
dataDatabase · 1 repos
accountingDatabase · 1 repos
actors_from_idsDatabase · 1 repos
analyticsDatabase · 1 repos
closedDatabase · 1 repos
contentDatabase · 1 repos

For agents

$ claude mcp add datasette \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact