Get the FREE Ultimate OpenClaw Setup Guide →

data-create-viz

Scanned
npx machina-cli add skill kevinlin/cowork-z/data-create-viz --openclaw
Files (1)
SKILL.md
4.8 KB

/create-viz - Create Visualizations

If you see unfamiliar placeholders or need to check which tools are connected, see CONNECTORS.md.

Create publication-quality data visualizations using Python. Generates charts from data with best practices for clarity, accuracy, and design.

Usage

/create-viz <data source> [chart type] [additional instructions]

Workflow

1. Understand the Request

Determine:

  • Data source: Query results, pasted data, CSV/Excel file, or data to be queried
  • Chart type: Explicitly requested or needs to be recommended
  • Purpose: Exploration, presentation, report, dashboard component
  • Audience: Technical team, executives, external stakeholders

2. Get the Data

If data warehouse is connected and data needs querying:

  1. Write and execute the query
  2. Load results into a pandas DataFrame

If data is pasted or uploaded:

  1. Parse the data into a pandas DataFrame
  2. Clean and prepare as needed (type conversions, null handling)

If data is from a previous analysis in the conversation:

  1. Reference the existing data

3. Select Chart Type

If the user didn't specify a chart type, recommend one based on the data and question:

Data RelationshipRecommended Chart
Trend over timeLine chart
Comparison across categoriesBar chart (horizontal if many categories)
Part-to-whole compositionStacked bar or area chart (avoid pie charts unless <6 categories)
Distribution of valuesHistogram or box plot
Correlation between two variablesScatter plot
Two-variable comparison over timeDual-axis line or grouped bar
Geographic dataChoropleth map
RankingHorizontal bar chart
Flow or processSankey diagram
Matrix of relationshipsHeatmap

Explain the recommendation briefly if the user didn't specify.

4. Generate the Visualization

Write Python code using one of these libraries based on the need:

  • matplotlib + seaborn: Best for static, publication-quality charts. Default choice.
  • plotly: Best for interactive charts or when the user requests interactivity.

Code requirements:

import matplotlib.pyplot as plt
import seaborn as sns
import pandas as pd

# Set professional style
plt.style.use('seaborn-v0_8-whitegrid')
sns.set_palette("husl")

# Create figure with appropriate size
fig, ax = plt.subplots(figsize=(10, 6))

# [chart-specific code]

# Always include:
ax.set_title('Clear, Descriptive Title', fontsize=14, fontweight='bold')
ax.set_xlabel('X-Axis Label', fontsize=11)
ax.set_ylabel('Y-Axis Label', fontsize=11)

# Format numbers appropriately
# - Percentages: '45.2%' not '0.452'
# - Currency: '$1.2M' not '1200000'
# - Large numbers: '2.3K' or '1.5M' not '2300' or '1500000'

# Remove chart junk
ax.spines['top'].set_visible(False)
ax.spines['right'].set_visible(False)

plt.tight_layout()
plt.savefig('chart_name.png', dpi=150, bbox_inches='tight')
plt.show()

5. Apply Design Best Practices

Color:

  • Use a consistent, colorblind-friendly palette
  • Use color meaningfully (not decoratively)
  • Highlight the key data point or trend with a contrasting color
  • Grey out less important reference data

Typography:

  • Descriptive title that states the insight, not just the metric (e.g., "Revenue grew 23% YoY" not "Revenue by Month")
  • Readable axis labels (not rotated 90 degrees if avoidable)
  • Data labels on key points when they add clarity

Layout:

  • Appropriate whitespace and margins
  • Legend placement that doesn't obscure data
  • Sorted categories by value (not alphabetically) unless there's a natural order

Accuracy:

  • Y-axis starts at zero for bar charts
  • No misleading axis breaks without clear notation
  • Consistent scales when comparing panels
  • Appropriate precision (don't show 10 decimal places)

6. Save and Present

  1. Save the chart as a PNG file with descriptive name
  2. Display the chart to the user
  3. Provide the code used so they can modify it
  4. Suggest variations (different chart type, different grouping, zoomed time range)

Examples

/create-viz Show monthly revenue for the last 12 months as a line chart with the trend highlighted
/create-viz Here's our NPS data by product: [pastes data]. Create a horizontal bar chart ranking products by score.
/create-viz Query the orders table and create a heatmap of order volume by day-of-week and hour

Tips

  • If you want interactive charts (hover, zoom, filter), mention "interactive" and Claude will use plotly
  • Specify "presentation" if you need larger fonts and higher contrast
  • You can request multiple charts at once (e.g., "create a 2x2 grid of charts showing...")
  • Charts are saved to your current directory as PNG files

Source

git clone https://github.com/kevinlin/cowork-z/blob/main/src-tauri/resources/skill-templates/data-create-viz/SKILL.mdView on GitHub

Overview

data-create-viz helps you generate publication-quality charts from data using Python. It guides you through understanding the request, loading data into a pandas DataFrame, selecting an appropriate chart type, and rendering the visualization with matplotlib/seaborn or Plotly, followed by design best practices for clarity and accuracy.

How This Skill Works

Workflow starts by clarifying the data source, chart type, purpose, and audience, then loads data into a DataFrame (or parses pasted/uploaded data). It selects a chart type (with recommendations if not specified) and renders the visualization using either matplotlib/seaborn for static charts or Plotly for interactivity, applying professional styling and axis labeling before saving the output.

When to Use It

  • You have a CSV, pasted data, or a data source and need a publication-quality chart for a report or slide deck.
  • The user didn't specify a chart type and you need to recommend one based on data relationships.
  • You want a static figure (publication or printed report) using matplotlib/seaborn.
  • You want an interactive chart for a dashboard or web presentation using Plotly.
  • You need colorblind-friendly palettes, clear typography, and accurate scales for credible visuals.

Quick Start

  1. Step 1: Define your data source and (optional) chart type in /create-viz <data source> [chart type].
  2. Step 2: Load data into a pandas DataFrame or parse pasted/uploaded data, cleaning as needed.
  3. Step 3: Generate the chart with matplotlib/seaborn (static) or Plotly (interactive) and save as an image.

Best Practices

  • Use a consistent, colorblind-friendly palette and highlight key data points with a contrasting color.
  • Write a descriptive title that states the insight (not just the metric).
  • Use readable axis labels and avoid unnecessary rotation; keep layout clean with appropriate whitespace.
  • Place legends to avoid obscuring data and sort categories by value when possible.
  • Ensure accuracy: start y-axes at zero for bars, avoid misleading breaks, and maintain consistent scales.

Example Use Cases

  • Line chart showing quarterly revenue trend to reveal YoY growth.
  • Horizontal bar chart comparing sales by category with many categories.
  • Histogram showing distribution of test scores to assess performance spread.
  • Scatter plot illustrating correlation between two variables (e.g., ad spend vs. conversions).
  • Choropleth map illustrating geographic distribution of metrics across regions.

Frequently Asked Questions

Add this skill to your agents
Sponsor this space

Reach thousands of developers