No project description provided
Project description
Shellviz Python Library
Shellviz is a zero-hassle Python tool that transforms your data into dynamic, real-time visualizations you can view right in your browser. It's lightweight, free, and has no dependencies — just install and start visualizing!
🛠️ Installation
Install Shellviz with pip:
pip install shellviz
If you want to integrate the Shellviz widget directly in your webpage, add the following script to your page:
<script src="https://unpkg.com/shellviz"></script>
🔧 Getting Started
Basic Usage
from shellviz import log, table, json
log('my first shellviz command')
# Shellviz serving on http://127.0.0.1:5544
table([("Alice", 25, 5.6), ("Bob", 30, 5.9)])
json({"name": "Alice", "age": 25, "height": 5.6})
Open the generated URL in your browser, and you'll see your data visualized instantly.
Advanced Usage
Update Existing Values
from shellviz import progress
progress(0.0, id='migration')
progress(1.0, id='migration') # Update data dynamically
Shellviz Server
Shellviz consists of a logging server and a client. The client first checks to see if an existing server is running, and initializes a server if one is not detected. This behavior can be configured with the SHELLVIZ_AUTO_START configuration setting. By default, a server is created unless a DEBUG environment variable is set to False.
The server can be manually initialized by calling the start_server method:
from shellviz import Shellviz
Shellviz().start_server()
Django Integration
Django Logging
Shellviz has an optional drop-in logging handler that can automatically initialize a Shellviz instance and forward all logging calls to it
LOGGING = {
'handlers': {
'shellviz': {
'class': 'shellviz.django.logging.ShellvizHandler',
# Automatically starts the server if DEBUG=True
# In production, set SHELLVIZ_AUTO_START=True to override
},
},
'root': {
'handlers': ['shellviz'],
'level': 'INFO',
},
}
By default, this handler starts a Shellviz server when DEBUG=True. This behavior can be overridden with the SHELLVIZ_AUTO_START configuration. See shellviz server for details.
Querysets and Models
Shellviz can encode Queryset and Model instances, so you can visualize ORM queries without having to serialize them
from shellviz import json, card
json(request.user)
card(User.objects.all())
Generic Timing Mixin
Shellviz includes a TimingMixin that automatically logs timing information for ALL method calls on any class. Simply inherit from TimingMixin and all your methods will be automatically timed:
# For Django CBVs
from django.views.generic import ListView
from shellviz.django import TimingMixin
class ProjectListView(TimingMixin, ListView):
model = Project
# ... other view configuration
# For any custom class
class MyCustomClass(TimingMixin):
def method_one(self):
# This will be automatically timed
pass
def method_two(self):
# This will also be automatically timed
pass
The mixin automatically intercepts and times ALL method calls, with timestamps relative to the start of the first method call.
Example output in Shellviz:
timing_ProjectListView: dispatch: 0.000s
timing_ProjectListView: get_queryset: 0.101s
timing_ProjectListView: get_context_data: 0.102s
timing_ProjectListView: render_to_response: 0.150s
timing_MyCustomClass: method_one: 0.100s
timing_MyCustomClass: method_two: 0.150s
Configuration
SHELLVIZ_PORT- Port number for the server (default: 5544)SHELLVIZ_SHOW_URL- Whether to show URL on startup (default: true)SHELLVIZ_URL- Custom base URL for the server (default: None, constructs from port)SHELLVIZ_AUTO_START- Whether the server should start automatically (default: DEBUG or True). See shellviz server for details.
If you're using Django, you can set these in your settings.py, e.g.:
# settings.py
SHELLVIZ_PORT = 8080
Usage Examples
Python Client
from shellviz import Shellviz
# Uses defaults: show_url=True, port=5544, url=None
# Overridden by Django settings or env vars if present
sv = Shellviz()
# Override specific settings
sv = Shellviz(port=9000, show_url=False)
# Use a custom URL
sv = Shellviz(url="https://my-server.com")
JavaScript Client
import { Shellviz } from 'shellviz';
// Uses configuration from process.env -> defaults
const sv = new Shellviz();
// Override specific settings
const sv = new Shellviz({ port: 9000, base_url: "https://my-server.com" });
JavaScript Server
import ShellvizServer from 'shellviz/server';
// Uses configuration from process.env -> defaults
const server = new ShellvizServer();
// Override settings
const server = new ShellvizServer({ port: 9000, showUrl: false });
Development
Build
Bundling and deploying Shellviz is straightforward. To automate the process of building the client, copying the necessary files, and compiling the Python package, use the provided build_with_latest_client.py script:
# From the libraries/python directory:
python build_with_latest_client.py
This script will:
- Build the Shellviz client (runs
npm installandnpm run buildin the client directory) - Copy the built client files into the Python package
- Build the Python package using Poetry
Once this is done, you can publish the package to PyPI:
poetry publish
To install into a local python environment, run the following command:
poetry add --no-cache ~/[path-to-repo]/dist/shellviz-0.x.x-py3-none-any.whl
Beta Versioning & TestPyPI Workflow
For testing and iterating on new features, Shellviz uses beta versioning following PEP 440 standards and TestPyPI for safe deployment testing.
Beta Version Format
Beta versions follow the format X.Y.Zb{number}:
0.5.0b1- First beta of version 0.5.00.5.0b2- Second beta of version 0.5.00.5.0b15- Fifteenth beta (final beta before release)
Update the version in pyproject.toml:
[tool.poetry]
version = "0.5.0b1"
Setting Up TestPyPI
TestPyPI is a separate instance of PyPI for testing package uploads without affecting the main PyPI repository.
-
Create TestPyPI Account Visit https://test.pypi.org/account/register/ to create an account.
-
Generate API Token
-
Click "Add API token"
-
Name it (e.g., "poetry-cli")
-
Set scope to "Entire account"
-
Copy the generated token (starts with
pypi-) -
Configure Poetry
# Add TestPyPI repository
poetry config repositories.test-pypi https://test.pypi.org/legacy/
# Set your API token (replace with your actual token)
poetry config pypi-token.test-pypi pypi-AgEIcHlwaS5vcmcCJGYwZjE3...
- Publishing to TestPyPI
# Build the package
poetry build
# Upload to TestPyPI
poetry publish -r test-pypi
- Installing from TestPyPI
# Install specific beta version
pip install --index-url https://test.pypi.org/simple/ shellviz==0.5.0b1
# Install latest pre-release
pip install --index-url https://test.pypi.org/simple/ --pre shellviz
or
First, add TestPyPI as a source in your target project:
poetry source add test-pypi https://test.pypi.org/simple/ --priority=explicit
Then install the beta package:
# Install specific beta version
poetry add shellviz==0.5.0b1 --source test-pypi
# Or allow pre-releases
poetry add shellviz --allow-prereleases --source test-pypi
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file shellviz-0.5.0.tar.gz.
File metadata
- Download URL: shellviz-0.5.0.tar.gz
- Upload date:
- Size: 21.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.6.1 CPython/3.9.17 Darwin/25.0.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
47a731e332fc3ae220c6fb8f518aa6fecd7f2ea98aea075d632e4181e8136c15
|
|
| MD5 |
24f91f81adb25350902e5e18411d13d3
|
|
| BLAKE2b-256 |
21da09c7cf26738651a5c0bce902d85e69b9af1a0db97dd8976e648b37942208
|
File details
Details for the file shellviz-0.5.0-py3-none-any.whl.
File metadata
- Download URL: shellviz-0.5.0-py3-none-any.whl
- Upload date:
- Size: 24.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.6.1 CPython/3.9.17 Darwin/25.0.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
790a145e4e67a9c587bbe2b17558a8226d1a59584e5af528a811812752c3494f
|
|
| MD5 |
b56dd41b9da782196c0df34cafe8e1b5
|
|
| BLAKE2b-256 |
8d7a073c969bdc2cefc761cabe537086e3de2b1c3098c8c6e98731b4f7932998
|