Convert Power BI (.pbix) files to Model Context Protocol (MCP) servers using Google's genai-toolbox
Project description
PBIX to MCP Converter
Convert Power BI (.pbix) files into Model Context Protocol (MCP) servers using Google's genai-toolbox.
Background
The pain point of any SQL generation solutions based on text2sql, either they are agentic or RAG, remain the same: they are depends on LLM which is non-deterministic! While they create greate applications, it raise the question whether the dynamically generated queries (effectively code) are acurate therefore the results from these query can be trusted or not.
Having been working on data domain for ages, my idea is to make best use of existing powerbi reports (tested code!) rather than dynamic generate query (image using a system with code generated on the fly!).
This tool do three things:
- Extract necessary information from powerbi reports (Thanks to
pbixray) - Convert to a yaml file according to Google's
genai-toolbox - Run
genai-toolboxto get a MCP server, which you can connect to with any MCP-supported assistant client
genai-toolbox allows you to pregenerated sql queries and expose them as MCP tool. So instead have LLM do everything: generate correct query, correct parameter, it now only need to make sure call the right tool, whose result can be easily spotted and evaluated.
Features
- Complete Data Extraction: Extract data models, tables, relationships, and schema information
- DAX Analysis: Parse DAX measures, calculated columns, and calculated tables with complexity analysis
- UI Structure: Extract report pages, visualizations, bookmarks, and layout information
- SQLite Database: Generate SQLite databases from embedded Power BI data
- MCP Configuration: Create genai-toolbox compatible YAML configurations
- Modular Architecture: Clean, extensible codebase for custom integrations
Quick Start
Here's an example of what this tool can extract from a Power BI report:
Original Power BI dashboard with complex visualizations and data relationships
The tool converts this into a comprehensive MCP server with dozens of specialized tools:
Generated MCP tools that provide programmatic access to all Power BI data and analytics
Once configured, you can interact with your Power BI data through natural language in any MCP-compatible chat interface:
Example of using the MCP tools in a chat interface to query Power BI data naturally
Installation
pip install pbix-to-mcp
Basic Usage
# Convert a Power BI file to MCP server
pbix-to-mcp report.pbix
# Generate complete package
pbix-to-mcp report.pbix --complete-package
# Custom output directory and configuration
pbix-to-mcp report.pbix -o my_output --config-name my_mcp.yaml
Using the MCP Server
-
Install Google's genai-toolbox:
# Download from releases page export VERSION=0.12.0 curl -O https://storage.googleapis.com/genai-toolbox/v$VERSION/linux/amd64/toolbox chmod +x toolbox
-
Start the MCP server:
./toolbox --tools-file supply_chain_mcp.yaml
Important: Ensure the database path in the YAML config is correct for your environment. If running from a different directory, you may need to update the database path to be absolute or correctly relative.
-
Connect from your MCP client:
{ "servers": { "powerbi-mcp": { "url": "http://localhost:5000/mcp", "headers": {} } } }
Library Usage
from pbix_to_mcp import PBIXConverter
# Initialize converter
converter = PBIXConverter("report.pbix")
# Extract all components
results = converter.extract_all()
# Generate MCP configuration
config_path = converter.generate_mcp_config("my_config.yaml")
# Generate complete package
package_files = converter.generate_complete_package()
Generated Tools
The converter creates comprehensive tool sets for interacting with your Power BI data:
Core Database Tools
execute_sql: Execute arbitrary SQL querieslist_powerbi_tables: List all available tablesdescribe_powerbi_table: Get table schema informationcount_table_records: Count records in any tableget_table_sample: Get sample data from tables
DAX Analysis Tools
get_dax_measures: Access DAX measure definitionssearch_dax_expressions: Search through DAX codeget_dax_complexity_analysis: Analyze DAX complexity metrics
UI Structure Tools
get_report_pages: Access report page informationget_visualizations_by_type: Query visualization metadataget_page_visual_layout: Get detailed visual layouts
Data-Specific Tools
- Table-specific analysis tools based on your data
- Aggregation queries for key metrics
- Relationship navigation helpers
Command Line Options
pbix-to-mcp report.pbix [options]
Options:
-o, --output-dir DIR Output directory
--config-name NAME MCP config file name
--skip-data Skip data model extraction
--skip-ui Skip UI structure extraction
--skip-dax Skip DAX expressions extraction
--data-limit N Maximum rows per table (default: 10000)
--complete-package Generate complete deployment package
--package-name NAME Package directory name
-v, --verbose Enable verbose logging
-q, --quiet Suppress console output
--log-file FILE Save logs to file
Output Structure
report_mcp/
├── data/
│ └── powerbi_data.db # SQLite database with all data
├── report_mcp_config.yaml # MCP server configuration
├── extraction_results.json # Complete extraction metadata
├── conversion.log # Detailed processing log
└── README.md # Generated documentation
Advanced Usage
Custom Extraction
from pbix_to_mcp.extractors import DataExtractor, UIExtractor, DAXExtractor
# Extract specific components
data_extractor = DataExtractor("report.pbix")
data_model = data_extractor.extract_data_model(data_limit=5000)
ui_extractor = UIExtractor("report.pbix")
ui_structure = ui_extractor.extract_ui_structure()
dax_extractor = DAXExtractor("report.pbix")
dax_expressions = dax_extractor.extract_all_dax()
Custom MCP Configuration
from pbix_to_mcp.generators import MCPConfigGenerator
generator = MCPConfigGenerator(output_dir)
config_path = generator.generate_config(
extraction_results,
config_name="custom_config.yaml",
toolsets=["basic-analysis", "dax-analysis"]
)
Requirements
- Python 3.10+
- pbixray>=0.3.3
- pandas>=1.5.0
- pyyaml>=6.0
- Google's genai-toolbox (for running MCP server)
Development
# Clone repository
git clone https://github.com/gavinHuang/pbix-to-mcp.git
cd pbix-to-mcp
# Install in development mode
pip install -e .[dev]
# Run tests
pytest
# Format code
black pbix_to_mcp/
isort pbix_to_mcp/
Contributing
- Fork the repository
- Create a feature branch
- Make your changes
- Add tests if needed
- Submit a pull request
License
MIT License - see LICENSE file for details.
Support
Acknowledgments
- Built on pbixray for Power BI file parsing
- Integrates with Google's genai-toolbox for MCP servers
- Inspired by the Model Context Protocol specification
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 pbix_to_mcp-0.1.0.tar.gz.
File metadata
- Download URL: pbix_to_mcp-0.1.0.tar.gz
- Upload date:
- Size: 39.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2740de9023df2ccc5089c8e5a6928c63723a6d1ee0028b207ac73798dccf63f9
|
|
| MD5 |
3aa4bf7da107829f125865bcc3a4f9be
|
|
| BLAKE2b-256 |
f4735973d698f469207ad58471a1835aee066282b6378201f431144116e5fe95
|
File details
Details for the file pbix_to_mcp-0.1.0-py3-none-any.whl.
File metadata
- Download URL: pbix_to_mcp-0.1.0-py3-none-any.whl
- Upload date:
- Size: 41.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
51dc380c4d77187c4e4e3a720359da6e84e95e5d4e4d5630201d1a2c5d075ec1
|
|
| MD5 |
195eb1c6aaa01721bcbbac76d5c04638
|
|
| BLAKE2b-256 |
086c55b4dd8a12f387b0088debe565b5548b49d19314c90f657f2f1e704518c9
|