plotly
Interactive visualization library for Python. Use it when you need hover tooltips, zoom/pan, selection, animations, or charts embeddable in web pages (e.g., dashboards, exploratory analysis, presentations).
Best use case
plotly is best used when you need a repeatable AI agent workflow instead of a one-off prompt.
Interactive visualization library for Python. Use it when you need hover tooltips, zoom/pan, selection, animations, or charts embeddable in web pages (e.g., dashboards, exploratory analysis, presentations).
Teams using plotly should expect a more consistent output, faster repeated execution, less prompt rewriting.
When to use this skill
- You want a reusable workflow that can be run more than once with consistent structure.
When not to use this skill
- You only need a quick one-off answer and do not need a reusable workflow.
- You cannot install or maintain the underlying files, dependencies, or repository context.
Installation
Claude Code / Cursor / Codex
Manual Installation
- Download SKILL.md from GitHub
- Place it in
.claude/skills/plotly/SKILL.mdinside your project - Restart your AI agent — it will auto-discover the skill
How plotly Compares
| Feature / Agent | plotly | Standard Approach |
|---|---|---|
| Platform Support | Not specified | Limited / Varies |
| Context Awareness | High | Baseline |
| Installation Complexity | Unknown | N/A |
Frequently Asked Questions
What does this skill do?
Interactive visualization library for Python. Use it when you need hover tooltips, zoom/pan, selection, animations, or charts embeddable in web pages (e.g., dashboards, exploratory analysis, presentations).
Where can I find the source code?
You can find the source code on GitHub using the link provided at the top of the page.
SKILL.md Source
> **Source**: [https://github.com/aipoch/medical-research-skills](https://github.com/aipoch/medical-research-skills)
# Plotly
## When to Use
- Use this skill when the request matches its documented task boundary.
- Use it when the user can provide the required inputs and expects a structured deliverable.
- Prefer this skill for repeatable, checklist-driven execution rather than open-ended brainstorming.
## Key Features
- Scope-focused workflow aligned to: Interactive visualization library for Python. Use it when you need hover tooltips, zoom/pan, selection, animations, or charts embeddable in web pages (e.g., dashboards, exploratory analysis, presentations).
- Documentation-first workflow with no packaged script requirement.
- Reference material available in `references/` for task-specific guidance.
- Structured execution path designed to keep outputs consistent and reviewable.
## Dependencies
- `Python`: `3.10+`. Repository baseline for current packaged skills.
- `Third-party packages`: `not explicitly version-pinned in this skill package`. Add pinned versions if this skill needs stricter environment control.
## Example Usage
```text
Skill directory: 20260316/scientific-skills/Others/plotly
No packaged executable script was detected.
Use the documented workflow in SKILL.md together with the references/assets in this folder.
```
Example run plan:
1. Read the skill instructions and collect the required inputs.
2. Follow the documented workflow exactly.
3. Use packaged references/assets from this folder when the task needs templates or rules.
4. Return a structured result tied to the requested deliverable.
## Implementation Details
- Execution model: validate the request, choose the packaged workflow, and produce a bounded deliverable.
- Input controls: confirm the source files, scope limits, output format, and acceptance criteria before running any script.
- Primary implementation surface: instruction-only workflow in `SKILL.md`.
- Reference guidance: `references/` contains supporting rules, prompts, or checklists.
- Parameters to clarify first: input path, output path, scope filters, thresholds, and any domain-specific constraints.
- Output discipline: keep results reproducible, identify assumptions explicitly, and avoid undocumented side effects.
## 1. When to Use
Use Plotly when you need interactive, shareable visualizations, especially in these scenarios:
- **Exploratory data analysis (EDA):** quickly inspect distributions, relationships, and outliers with hover and selection.
- **Dashboards and web embedding:** publish interactive charts to HTML pages or integrate into web apps (e.g., Dash).
- **Time-series monitoring:** use range sliders, zooming, and pan for dense temporal data.
- **Presentations and stakeholder reviews:** interactive tooltips and legend toggling help explain results live.
- **Complex multi-panel figures:** build subplots and multi-trace figures with fine-grained layout control.
If you only need static publication figures, consider Matplotlib or other scientific visualization tools.
## 2. Key Features
- **Two APIs**
- **Plotly Express (`plotly.express`, `px`)**: high-level, concise API for common charts from DataFrames.
- **Graph Objects (`plotly.graph_objects`, `go`)**: low-level building blocks for full control and custom figures.
- Plotly Express returns a **Graph Objects `Figure`**, so you can mix both styles.
- **40+ chart types** across statistical, scientific, financial, geospatial, and 3D categories.
- **Interactivity by default**
- hover tooltips, zoom/pan, legend toggling
- box/lasso selection
- range sliders (time series)
- buttons/dropdowns and animations
- **Layout and styling**
- subplots (`make_subplots`)
- templates (e.g., `plotly_dark`, `plotly_white`)
- annotations, shapes, axes/legend control
- **Export**
- interactive HTML (`write_html`)
- static images via Kaleido (`write_image`)
Reference guides (optional reading):
- Plotly Express: `reference/plotly-express.md`
- Graph Objects: `reference/graph-objects.md`
- Chart catalog: `reference/chart-types.md`
- Layout & styling: `reference/layouts-styling.md`
- Export & interactivity: `reference/export-interactivity.md`
## 3. Dependencies
- `plotly>=5.0`
- `pandas>=1.5` (recommended for DataFrame-based workflows)
- `kaleido>=0.2` (optional, required for static image export: PNG/SVG/PDF)
- `dash>=2.0` (optional, for building interactive web apps)
## 4. Example Usage
A complete runnable example demonstrating: Plotly Express + Graph Objects updates, hover customization, subplots, and export.
### Install
```bash
uv pip install "plotly>=5.0" "pandas>=1.5" "kaleido>=0.2"
```
### Run
```python
import pandas as pd
import plotly.express as px
import plotly.graph_objects as go
from plotly.subplots import make_subplots
def main():
# Sample dataset
df = pd.DataFrame(
{
"x": [1, 2, 3, 4, 5],
"y": [10, 11, 12, 11.5, 13],
"group": ["A", "A", "B", "B", "B"],
}
)
# 1) Quick chart with Plotly Express
fig_scatter = px.scatter(
df,
x="x",
y="y",
color="group",
title="Scatter (px) + Graph Objects Updates",
template="plotly_white",
)
# 2) Use Graph Objects methods on a px figure
fig_scatter.update_traces(
hovertemplate="x=%{x}<br>y=%{y:.2f}<br>group=%{marker.color}<extra></extra>"
)
fig_scatter.add_hline(y=11, line_dash="dash", line_color="gray")
# 3) Build a small dashboard-like layout with subplots
fig = make_subplots(
rows=1,
cols=2,
subplot_titles=("Interactive Scatter", "Group Means (Bar)"),
specs=[[{"type": "scatter"}, {"type": "bar"}]],
)
# Left: reuse traces from the px figure
for tr in fig_scatter.data:
fig.add_trace(tr, row=1, col=1)
# Right: bar chart with group means
means = df.groupby("group", as_index=False)["y"].mean()
fig.add_trace(
go.Bar(x=means["group"], y=means["y"], name="mean(y)"),
row=1,
col=2,
)
fig.update_layout(
title="Plotly End-to-End Example",
height=450,
legend_title_text="Group",
margin=dict(l=40, r=20, t=70, b=40),
)
# Show interactively (notebook or supported environment)
fig.show()
# Export
fig.write_html("plotly_example.html", include_plotlyjs="cdn")
fig.write_image("plotly_example.png") # requires kaleido
if __name__ == "__main__":
main()
```
## 5. Implementation Details
### API choice: `px` vs `go`
- **Use `plotly.express` (`px`)** when:
- your data is in a Pandas DataFrame,
- you want fast defaults and concise code,
- you need standard charts (scatter/line/bar/histogram/box/violin, etc.).
- **Use `plotly.graph_objects` (`go`)** when:
- you need precise control over traces, axes, annotations, shapes, or multi-trace composition,
- you are building uncommon chart types or highly customized figures.
- **Mixing is standard**: `px.*` returns a `go.Figure`, so `fig.update_layout(...)`, `fig.add_trace(...)`, `fig.add_hline(...)`, etc. work seamlessly.
### Interactivity configuration
- **Hover formatting**: customize per-trace with `hovertemplate` to control text and numeric formatting.
- **Time-series navigation**: enable range sliders via:
- `fig.update_xaxes(rangeslider_visible=True)`
- **Selection tools**: box/lasso selection is available by default in many chart types; you can further configure selection behavior via trace/layout options.
### Export behavior
- **HTML export** (`write_html`) preserves full interactivity.
- `include_plotlyjs="cdn"` reduces file size but requires internet access to load Plotly JS.
- **Static export** (`write_image`) requires **Kaleido** and produces PNG/SVG/PDF suitable for reports.
## When Not to Use
- Do not use this skill when the required source data, identifiers, files, or credentials are missing.
- Do not use this skill when the user asks for fabricated results, unsupported claims, or out-of-scope conclusions.
- Do not use this skill when a simpler direct answer is more appropriate than the documented workflow.
## Required Inputs
- A clearly specified task goal aligned with the documented scope.
- All required files, identifiers, parameters, or environment variables before execution.
- Any domain constraints, formatting requirements, and expected output destination if applicable.
## Recommended Workflow
1. Validate the request against the skill boundary and confirm all required inputs are present.
2. Select the documented execution path and prefer the simplest supported command or procedure.
3. Produce the expected output using the documented file format, schema, or narrative structure.
4. Run a final validation pass for completeness, consistency, and safety before returning the result.
## Output Contract
- Return a structured deliverable that is directly usable without reformatting.
- If a file is produced, prefer a deterministic output name such as `plotly_result.md` unless the skill documentation defines a better convention.
- Include a short validation summary describing what was checked, what assumptions were made, and any remaining limitations.
## Validation and Safety Rules
- Validate required inputs before execution and stop early when mandatory fields or files are missing.
- Do not fabricate measurements, references, findings, or conclusions that are not supported by the provided source material.
- Emit a clear warning when credentials, privacy constraints, safety boundaries, or unsupported requests affect the result.
- Keep the output safe, reproducible, and within the documented scope at all times.
## Failure Handling
- If validation fails, explain the exact missing field, file, or parameter and show the minimum fix required.
- If an external dependency or script fails, surface the command path, likely cause, and the next recovery step.
- If partial output is returned, label it clearly and identify which checks could not be completed.
## Quick Validation
Run this minimal verification path before full execution when possible:
```text
No local script validation step is required for this skill.
```
Expected output format:
```text
Result file: plotly_result.md
Validation summary: PASS/FAIL with brief notes
Assumptions: explicit list if any
```Related Skills
skill-auditor
A comprehensive auditor for any agent skill — including Manus, OpenClaw/ClawHub, Claude, LobeHub, or custom SKILL.md-based skills. Use this skill whenever a user wants to evaluate, audit, review, score, or quality-check an agent skill before publishing, updating, or deploying. Covers two hard veto gates (structural redlines + research integrity redlines), static quality scoring across 25 criteria (ISO 25010 + OpenSSF + Agent), dynamic test input generation, multi-mode execution testing, multi-layer output evaluation with five specialized category rubrics (Evidence Insight / Protocol Design / Data Analysis / Academic Writing / Other), a Research Veto that applies to all four research categories, human eval viewer generation, actionable P0/P1/P2 optimization recommendations, and automatic skill improvement that outputs a polished, production-ready SKILL.md. Also use whenever a user says "audit my skill", "evaluate my skill", "improve my skill", or wants a corrected version after evaluation.
two-sample-mr-research-planner
Generates complete two-sample Mendelian randomization (MR) research designs from a user-provided research direction. Use when users want to design, plan, or build a study using two-sample MR to test causal relationships. Triggers:"design a two-sample MR study", "build a publishable MR paper", "test whether this biomarker causally affects this disease", "generate Lite/Standard/Advanced MR plans", "screen multiple exposures with MR", "bidirectional MR design", "causal inference using GWAS summary statistics", or "I want to study X and Y using MR". Always outputs four workload configurations (Lite / Standard / Advanced / Publication+) with a recommended primary plan, step-by-step workflow, figure plan, validation strategy, minimal executable version, and publication upgrade path.
research-proposal-generator
Generates a comprehensive research proposal design based on input literature, including hypothesis, mechanism verification, and budget. Use when the user wants to design a research project from a paper.
research-grants
Write competitive research proposals for NSF, NIH, DOE, DARPA, and Taiwan's NSTC when you need agency-compliant narratives, budgets, and review-criteria alignment for a specific solicitation/FOA/BAA.
protocol-standardization
Standardize fragmented experimental steps into reproducible protocol documents when you need method organization, lab SOP drafting, or cross-operator reproducibility; missing parameters must be explicitly marked as "To be supplemented/Not provided".
prospero-registration-helper
Assists researchers in generating PROSPERO registration content for meta-analyses from a title and optional protocol. Use when the user wants to draft a PROSPERO registration form.
non-tumor-ml-research-planner
Generates complete non-tumor biomedical machine learning research designs from a user-provided research direction. Always use this skill when users want to plan bioinformatics + ML papers for non-cancer diseases (metabolic, cardiovascular, kidney, inflammatory, autoimmune, infectious, neurological, endocrine, wound healing, chronic multifactor), design diagnostic biomarker studies, combine GEO datasets with feature selection and ML modeling, or generate Lite/Standard/Advanced/Publication+ workload plans. Trigger for:"non-tumor ML study", "bioinformatics paper outside oncology", "key genes and diagnostic model for a disease", "pyroptosis/ferroptosis/senescence/autophagy + disease", "GEO datasets + machine learning", "RF + LASSO diagnostic model", "DEG + feature selection + validation", "immune infiltration + biomarker", "non-cancer biomarker paper". Trigger even for casual phrasings like "I want to study X using machine learning", "help me design a non-tumor bioinformatics paper", or "how do I build a diagnostic model for disease Y".
network-tox-docking-research-planner
Generates complete network toxicology + molecular docking research designs from a user-provided toxicant and disease/phenotype. Always use this skill when users want to investigate how an environmental toxicant, endocrine disruptor, heavy metal, food contaminant, pharmaceutical residue, or consumer product chemical may contribute to a disease through shared molecular targets, hub genes, pathways, and docking evidence. Trigger for:"network toxicology study", "toxicology mechanism paper", "target prediction + PPI + docking", "environmental pollutant and disease mechanism", "hub genes and docking for toxicant", "Lite/Standard/Advanced toxicology plan", "CTD + SwissTargetPrediction + GeneCards + STRING", "CB-Dock2 docking study", "triclosan/BPA/cadmium/PFAS + disease". Also triggers for Chinese phrasings:"网络毒理学研究设计"、"毒物机制论文"、"靶点预测+PPI+对接"、"环境污染物与疾病机制". Trigger even for casual phrasings like "I want to study how chemical X affects disease Y" or "help me design a toxicology paper". Always output four workload configurations (Lite / Standard / Advanced / Publication+) with a recommended primary plan, step-by-step workflow, figure plan, validation strategy, minimal executable version, and publication upgrade path.
meta-protocol-writer
Generates a PROSPERO-compliant Meta-analysis protocol based on Title and PICOS. Use when the user wants to write a protocol for a systematic review or meta-analysis.
hypothesis-generation
Structured scientific hypothesis formulation from observations; use when you have experimental observations or preliminary data and need testable hypotheses with predictions, mechanisms, and validation experiments.
hypogenic
Automated LLM-driven hypothesis generation and testing for tabular datasets; use when you need systematic exploration of empirical patterns (e.g., fraud detection, content analysis) and want to combine literature insights with data-driven hypothesis evaluation.
faers-multi-drug-soc-planner
Generates complete FAERS-based multi-drug single-SOC safety comparison research designs from a user-provided drug set, comparator, and adverse event domain. Always use this skill when users want to compare safety signals across multiple drugs using FAERS or OpenFDA data within one System Organ Class (SOC) or bounded AE domain. Trigger for:"FAERS study comparing drugs within one SOC", "publishable FAERS safety comparison paper", "compare neuropsychiatric adverse events across beta-blockers", "Lite/Standard/Advanced FAERS safety plans", "active-comparator restricted disproportionality", "adjusted ROR logistic regression FAERS", "within-class head-to-head drug comparison", "pharmacovigilance signal comparison", "single-SOC PT-level FAERS design", or any phrasing like "I want to compare drug X and drug Y for adverse events in FAERS" or "build a comparative pharmacovigilance paper". Always output four workload configurations (Lite / Standard / Advanced / Publication+) with a recommended primary plan, step-by-step workflow, figure plan, validation strategy, minimal executable version, and publication upgrade path.