Power-bi-agentic-development standardize-naming-conventions
Interactive naming convention standardization for TMDL-based Power BI semantic models. Automatically invoke when the user asks to "standardize naming conventions", "fix naming conventions", "clean up model names", "apply naming standards", "audit naming", "make names human readable", "rename fields", "fix abbreviations in model", or mentions renaming measures, columns, or tables for consistency across a model.
git clone https://github.com/data-goblin/power-bi-agentic-development
T=$(mktemp -d) && git clone --depth=1 https://github.com/data-goblin/power-bi-agentic-development "$T" && mkdir -p ~/.claude/skills && cp -r "$T/plugins/semantic-models/skills/standardize-naming-conventions" ~/.claude/skills/data-goblin-power-bi-agentic-development-standardize-naming-conventions && rm -rf "$T"
plugins/semantic-models/skills/standardize-naming-conventions/SKILL.mdStandardize Naming Conventions
Interactive workflow for auditing and standardizing naming conventions in Power BI semantic models stored as TMDL files. Ensures tables, columns, measures, and display folders follow human-readable, consistent, business-aligned naming standards.
Primary Workflow
Phase 1: Discover the Model
Locate the TMDL files. Ask the user for the path to the
.SemanticModel/definition/ directory if not obvious from context. Then scan the model structure:
# Count tables and get an overview ls <path>/tables/*.tmdl
Read all table TMDL files to build a complete picture of current naming patterns. Focus on:
- Table names (check for DIM_, FACT_, or other technical prefixes)
- Measure names (check for abbreviations, programming conventions, inconsistent syntax)
- Column names (check for CamelCase, snake_case, abbreviations)
- Display folder structure (check for organization and consistency)
- Presence of descriptions (
comments)///
Phase 2: Understand Business Context
CRITICAL: Do not rename anything without understanding the business terminology.
Use
AskUserQuestion to gather context:
- Business terminology: "What terminology does your organization use for key metrics? For example, do you call it Revenue, Turnover, Sales, or Gross Sales?"
- Existing conventions: "Do you have any documented naming conventions or standards already?"
- Period conventions: "How do you typically refer to prior periods? (e.g., 1YP, PY, Prior Year, Last Year)"
- Unit conventions: "How do you typically express units in measure names? (e.g., parentheses like (%), (Value), (Quantity))"
- Downstream impact: "Are there downstream reports connected to this model that would need visual rebinding after renaming?"
Adapt the naming rules to the user's business context. The rules in
references/naming-rules.md are defaults -- override them when the user's organization has established conventions.
Phase 3: Audit and Report
Before making changes, produce an audit report. Present a markdown table showing each proposed rename:
| Object Type | Current Name | Proposed Name | Issues Found | |-------------|-------------|---------------|-------------| | Table | FACT_Invoices | Invoices | Technical prefix | | Measure | NetSls | Net Sales | CamelCase, abbreviation | | Column | shp_dt | Ship Date | snake_case, abbreviation |
Group findings by issue type:
- Programming conventions: CamelCase, snake_case, UPPER_CASE
- Abbreviations/acronyms: Shortened or opaque names
- Inconsistent syntax: Mixed period, unit, or aggregation patterns
- Technical prefixes: DIM_, FACT_, STG_ on tables
- Missing descriptions: Objects without
docstrings/// - Disorganized folders: Missing or flat display folder hierarchy
Ask the user to confirm or adjust the proposed renames before proceeding.
Phase 4: Apply Changes
After user approval, edit the TMDL files. For each table file:
- Rename the table (if needed): Change the
declarationtable - Rename measures: Change measure names in their declarations. IMPORTANT: Also update all internal DAX references to renamed measures using
->[Old Name]
patterns across ALL table files in the model[New Name] - Rename columns: Change column names in their declarations. IMPORTANT: Also update DAX references using
->'Table'[Old Column]
across ALL table files'Table'[New Column] - Reorganize display folders: Add or restructure
propertiesdisplayFolder: - Add descriptions: Add
comments for measures and columns that lack them/// - Update relationship references: Check
for renamed tables/columnsrelationships.tmdl
Cross-file reference updates are critical. When renaming a measure or column, search the entire
definition/ directory for all references:
# Find all references to a renamed measure rg "OldMeasureName" <path>/definition/tables/ rg "OldMeasureName" <path>/definition/relationships.tmdl
Phase 5: Validate
After applying changes, verify:
- All TMDL files still parse correctly (no syntax errors)
- No orphaned references to old names remain in any file
- Display folders are consistent across tables
- Descriptions are present on all visible measures and columns
Run a final search to check for any missed references:
# Check for any remaining old names rg -n "old_name_pattern" <path>/definition/
Naming Convention Rules
Consult
references/naming-rules.md for the complete rule set including:
- Human-readable name requirements
- Abbreviation and acronym rules
- Technical prefix rules
- Aggregation, unit, and period syntax standards
- Display folder organization patterns
- Measure name construction order:
[Aggregation] [Base Name] [Period] ([Unit]) - Column naming patterns
Key Anti-Patterns to Detect
Quick-reference checklist for the most common issues:
| Anti-Pattern | Rule | Example Fix |
|---|---|---|
| Use spaces | -> |
| Use spaces | -> |
| Use spaces | -> |
| Abbreviations | Spell out | -> |
| Opaque acronyms | Spell out | -> |
| Technical prefix | Remove | -> |
| Inconsistent periods | Standardize | // -> |
| Inconsistent units | Standardize | // -> |
| Missing descriptions | Add | docstrings on all visible objects |
| Flat folders | Organize | Numbered hierarchy with subfolders |
Downstream Report Impact
WARNING: Renaming model objects breaks downstream report visuals that reference those fields. After renaming:
- Identify all connected reports (
files or Power BI Service reports).pbir - Rebind visuals to use the new field names
- This can be done manually in Power BI Desktop, or programmatically by editing the
files in PBIR formatvisual.json
Always warn the user about this before applying renames. If downstream reports exist, consider:
- Making a backup of the model before changes
- Planning a rebinding session after the rename
- Using a C# script in Tabular Editor to batch-rename with rebinding
Additional Resources
Reference Files
-- Complete naming convention rules with detection patterns, anti-pattern tables, and the measure name construction orderreferences/naming-rules.md
Fetching Docs
To retrieve current semantic model and TMDL reference docs, use
microsoft_docs_search + microsoft_docs_fetch (MCP) if available, otherwise mslearn search + mslearn fetch (CLI). Search based on the user's request and run multiple searches as needed to ensure sufficient context before proceeding.