An open API service indexing awesome lists of open source software.

https://github.com/StructuredLabs/preswald

Preswald is a WASM packager for Python-based interactive data apps: bundle full complex data workflows, particularly visualizations, into single files, runnable completely in-browser, using Pyodide, DuckDB, Pandas, and Plotly, Matplotlib, etc. Build dashboards, reports, and notebooks that run offline, load fast, and share like a document.
https://github.com/StructuredLabs/preswald

ai analytics analytics-engineering copilot data data-applications data-infrastructure data-pipelines data-sdk data-visualization gpt llm open-source python schema-management vscode

Last synced: 1 day ago
JSON representation

Preswald is a WASM packager for Python-based interactive data apps: bundle full complex data workflows, particularly visualizations, into single files, runnable completely in-browser, using Pyodide, DuckDB, Pandas, and Plotly, Matplotlib, etc. Build dashboards, reports, and notebooks that run offline, load fast, and share like a document.

Awesome Lists containing this project

README

        


Banner


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.




Apache 2.0 License


Python Version


Slack Community


PyPI Version



Website


Documentation


Studio


Book a Demo

## **What is Preswald?**

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

## **Key Features**

- 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

## Export as a Static App

```bash
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

## **Installation**

https://pypi.org/project/preswald/

```bash
pip install preswald

or

uv pip install preswald
```

![Demo GIF](assets/demo1.gif)

## **Quick Start**

```bash
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.

```python
from preswald import text, table, get_df

text("# Hello Preswald")
df = get_df("sample.csv")
table(df)
...
```

Now run your app locally with:

```bash
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!

## **Configuration**

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"
```

## **Use Cases**

- 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]()


## **📚 Documentation**

We’re here to help! Check out our full documentation at [Preswald Docs](https://docs.preswald.com/).


## **🤝 Contributing**

Check out [CONTRIBUTING.md](CONTRIBUTING.md).


## **🎉 Join the Community**

- **GitHub Issues**: Found a bug? Let us know [here](https://github.com/StructuredLabs/preswald/issues).
- **Community Forum**: Reach out [here](https://join.slack.com/t/structuredlabs-users/shared_invite/zt-33zwhyv3l-6Xu4bHL6b6~bI3z9fvlUig)
- **Discussions**: Share your ideas and ask questions in our [discussion forum](https://github.com/StructuredLabs/preswald/discussions).
- **Contributors**: Meet the awesome people who make Preswald better [here](https://github.com/StructuredLabs/preswald/graphs/contributors).


## **📢 Stay Connected**



Follow us on LinkedIn


Follow us on Twitter

## **📄 License**

Preswald is licensed under the [Apache 2.0 License](LICENSE).

## ✨ Contributors

Thanks to everyone who has contributed to Preswald 💜

[![](https://contrib.rocks/image?repo=StructuredLabs/preswald)](https://github.com/StructuredLabs/preswald/graphs/contributors)