Metadata-Version: 2.4
Name: dumont
Version: 0.7.1
Summary: Excel file generation tool with pivot tables, charts, dashboards, and AI analysis
Author: Dumont Developer
License: MIT
Project-URL: Homepage, https://github.com/tojlon/dumont
Project-URL: Repository, https://github.com/tojlon/dumont
Keywords: excel,pivot,pandas,charts,matplotlib,cli,dashboard,ai,ollama
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Requires-Python: >=3.10
Description-Content-Type: text/markdown
Requires-Dist: pandas>=1.5.0
Requires-Dist: xlsxwriter>=3.0.0
Requires-Dist: click>=8.0.0
Requires-Dist: openpyxl>=3.0.0
Requires-Dist: matplotlib>=3.7.0
Provides-Extra: dev
Requires-Dist: pytest>=7.0.0; extra == "dev"
Requires-Dist: black>=23.0.0; extra == "dev"
Requires-Dist: ruff>=0.1.0; extra == "dev"
Provides-Extra: web
Requires-Dist: fastapi>=0.100.0; extra == "web"
Requires-Dist: uvicorn>=0.22.0; extra == "web"
Provides-Extra: ai
Requires-Dist: ollama>=0.1.0; extra == "ai"
Provides-Extra: cloud
Requires-Dist: groq>=0.4.0; extra == "cloud"
Provides-Extra: all
Requires-Dist: dumont[ai,cloud,web]; extra == "all"

# Dumont

Excel file generation tool with pivot tables, charts, dashboards, and AI analysis

## Try it Online

Use Dumont directly in your browser - no installation required:

**https://dumont-1npt.onrender.com**

## Installation

```bash
pip install dumont
```

## Features

- **Pivot Tables**: Configurable aggregations (sum, mean, count, min, max)
- **Charts**: Bar, line, pie, doughnut, scatter, area
- **Dashboard**: KPI cards with global filters and configurable aggregations
- **AI Analysis**: Natural language insights powered by Ollama (local LLM)
- **Professional Formatting**: Green headers, borders, autofilter, freeze panes
- **Multiple Interfaces**: CLI, Python API, and Web UI

## CLI Usage

### Create a Chart

```bash
# Bar chart from sample data
dumont chart -o sales.png -t bar -x Category -y Revenue

# Pie chart from CSV
dumont chart -i data.csv -t pie -x Category -y Revenue -o chart.png

# Line chart with grouping
dumont chart -t line -x Category -y Revenue --group-by Region -o trend.png
```

### Export Excel with Charts

```bash
# Excel with data, pivot table, and bar chart
dumont export -o report.xlsx

# Excel with pie chart
dumont export -o report.xlsx --chart pie

# Excel without chart
dumont export -o report.xlsx --chart none

# From CSV input
dumont export -i data.csv -o report.xlsx --chart line
```

### Generate Excel (pivot only)

```bash
# With sample data
dumont generate -o sales_report.xlsx

# From CSV/Excel input
dumont generate -i data.csv -o report.xlsx

# Custom pivot configuration
dumont generate -o report.xlsx \
    --pivot-values Revenue \
    --pivot-index Category \
    --pivot-columns Region \
    --aggfunc sum
```

### Other Commands

```bash
# Preview sample data
dumont sample --rows 20

# Preview Excel file
dumont preview report.xlsx --sheet Data --rows 10

# Get file info
dumont info report.xlsx

# Start local web server
dumont serve
```

## Web UI

Dumont includes a browser-based spreadsheet interface.

### Online Version

Use it directly at: **https://dumont-1npt.onrender.com**

### Local Server

```bash
dumont serve
# Open http://127.0.0.1:8000
```

### Web UI Features

- **Spreadsheet Interface**: Excel-like grid with cell editing and keyboard navigation
- **Data Loading**: Load sample data or upload CSV/Excel files
- **Pivot Tables**: Create and preview pivot tables with configurable options
- **Charts**: Create interactive charts (bar, line, pie, doughnut, scatter, area)
- **Dashboard**: View KPIs with global filters (Region, Category, Product, etc.)
- **Export**: Download formatted Excel files with data, pivot tables, and charts

### Dashboard

The Dashboard tab provides a KPI overview of your data with interactive filtering.

**Features:**
- **3 Configurable KPI Cards**: Display key metrics at a glance
- **Global Filters**: Filter by Region, Category, Product, or any column in your data
- **Aggregations**: Sum, Average, Count, Min, Max
- **Custom Titles**: Rename each KPI card

**How to use:**
1. Load data (sample or upload CSV/Excel)
2. Click the **Dashboard** button or tab
3. Use the filter dropdowns to narrow your data
4. Click **KPI Settings** to configure each card:
   - Select the column to aggregate
   - Choose the aggregation function
   - Set a custom title

### AI Analysis

Get natural language insights about your data using local AI (Ollama).

**Setup:**
```bash
# Install Ollama (https://ollama.ai)
# Then pull a model:
ollama pull llama3.2

# Install dumont with AI support:
pip install dumont[ai]
```

**How to use:**
1. Load data and go to the Dashboard tab
2. Apply filters if needed
3. Click **Analyze Data** to get AI-powered insights
4. The AI will analyze your data and provide 4-5 sentences of business insights

**Note:** AI analysis runs locally on your machine using Ollama. No data is sent to external servers.

## Python API

```python
from dumont import create_excel_with_charts, create_chart, generate_sample_data

# Create chart image
df = generate_sample_data(rows=100)
create_chart(
    df=df,
    output_path="sales_chart.png",
    chart_type="bar",
    x_axis="Category",
    y_axis="Revenue",
    aggfunc="sum",
)

# Create Excel with pivot and chart
create_excel_with_charts(
    output_path="report.xlsx",
    use_sample_data=True,
    pivot_values="Revenue",
    pivot_index="Category",
    pivot_columns="Region",
    charts=[{
        "chart_type": "bar",
        "x_axis": "Category",
        "y_axis": "Revenue",
        "aggfunc": "sum",
    }],
)

# Use your own DataFrame
import pandas as pd

df = pd.read_csv("my_data.csv")
create_excel_with_charts(
    output_path="report.xlsx",
    df=df,
    pivot_values="Sales",
    pivot_index="Product",
    pivot_columns="Quarter",
    charts=[{"chart_type": "line", "x_axis": "Product", "y_axis": "Sales"}],
)
```

## Output Structure

Generated Excel files contain:

1. **Data Sheet**: Raw data with formatting and autofilter
2. **Pivot Sheet**: Pivot table with totals row highlighted
3. **Charts Sheet**: Embedded chart images (when charts are included)

## Chart Types

| Type | Description |
|------|-------------|
| `bar` | Vertical bar chart |
| `line` | Line chart with markers |
| `pie` | Pie chart with percentages |
| `doughnut` | Doughnut chart |
| `scatter` | Scatter plot |
| `area` | Area chart |

## Requirements

- Python 3.10+
- pandas
- xlsxwriter
- click
- openpyxl
- matplotlib

## License

MIT
