Create interactive data apps with a full data stack that runs in the browser (no local dependencies!),runs offline, and is shareable in a single file.
Preswald is a static-site generator for building interactive data apps in Python. It packages compute, data access, and UI into self-contained data apps that run locally in the browser. Built on a WASM runtime with Pyodide and DuckDB, Preswald enables portable, file-based apps that are fast, reactive, and shareable.
You can think of Preswald as a lightweight alternative to heavier web app platforms. It provides built-in UI components and reactive state tracking, so you can use it to build dashboards, reports, prototypes, workflows, and notebooks that are reactive, portable, and secure by default.
Preswald is especially useful when:
- You want to bundle logic, UI, and data into a shareable file
- You need to ship a tool to a stakeholder who shouldn't need to install anything
- You're working with sensitive data and want full local control
- You want to give AI systems structured, modifiable tools
- Code-based. Write apps in Python, not in notebooks or JS frameworks
- File-first. One command creates a fully-packaged
.html
app - Built for computation. Use Pyodide + DuckDB directly in-browser
- Composable UI. Use prebuilt components like tables, charts, forms
- Reactive engine. Only re-run what's needed, powered by a DAG of dependencies
- Local execution. No server. Runs offline, even with large data
- AI-ready. Apps are fully inspectable and modifiable by agents
preswald export
This command builds your app into a static site inside dist/
. The folder contains all the files needed to run your app locally or share it.
- Works offline in any modern browser
- Bundles your Python code (via Pyodide), data, and DuckDB queries
- Preserves app UI, logic, and reactive state
- Shareable as a file folder or embeddable in hosting platforms
https://pypi.org/project/preswald/
pip install preswald
or
uv pip install preswald
pip install preswald
preswald init my_app
cd my_app
preswald run
This will create a folder called my_app
:
my_app/
├── hello.py # Your app logic
├── preswald.toml # App metadata and config
├── secrets.toml # Secrets (e.g. API keys)
├── data/sample.csv # Input data files
├── images/logo.png # Custom branding
Edit hello.py
to build your app.
from preswald import text, table, get_df
text("# Hello Preswald")
df = get_df("sample.csv")
table(df)
...
Now run your app locally with:
preswald run
This command launches a development server, and Preswald will let you know where your app is hosted. Typically, it’s here:
🌐 App running at: http://localhost:8501
Open your browser, and voilà—your first Preswald app is live!
Preswald uses a simple preswald.toml
file for configuration. This defines the app's metadata, runtime settings, UI branding, and data sources. Here's a sample:
[project]
title = "Preswald Project"
version = "0.1.0"
port = 8501
slug = "preswald-project"
entrypoint = "hello.py"
[branding]
name = "Preswald Project"
logo = "images/logo.png"
favicon = "images/favicon.ico"
primaryColor = "#F89613"
[logging]
level = "INFO" # Options: DEBUG, INFO, WARNING, ERROR, CRITICAL
format = "%(asctime)s - %(name)s - %(levelname)s - %(message)s"
- Analyst dashboards. Build data summaries and visualizations. Share as static sites. Example 1 Example 2 Example 3
- Interactive reports. Deliver notebooks and reports that update live based on user input. Example 1 Example 2 Example 3
- Data inspection tools. Explore files, logs, or snapshots with quick, purpose-built UIs.Example 1 Example 2 Example 3
- Offline kits. Package apps for fieldwork or secure / airgap settings. Example 1 Example 2 Example 3
- Experiment panels. Compare runs, track metrics, and present results in standalone interactive apps. Example 1 Example 2 Example 3
We’re here to help! Check out our full documentation at Preswald Docs.
Check out CONTRIBUTING.md.
- GitHub Issues: Found a bug? Let us know here.
- Community Forum: Reach out here
- Discussions: Share your ideas and ask questions in our discussion forum.
- Contributors: Meet the awesome people who make Preswald better here.
Preswald is licensed under the Apache 2.0 License.
Thanks to everyone who has contributed to Preswald 💜