Skip to content

JamesDBartlett3/ps-for-pbi

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

71 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Table of Contents

Authors

Introduction

This repository contains PowerShell scripts that can be used to streamline and automate tasks in Power BI.

Prerequisites

Usage

  1. Open PowerShell (pwsh)
  2. Install any PowerShell modules required by the script(s) you want to run, e.g.:
    Install-Module -Name MicrosoftPowerBIMgmt, ImportExcel, DataGateway, Microsoft.PowerShell.ConsoleGuiTools -Scope CurrentUser
  3. Allow PowerShell to run scripts downloaded from the Internet
    Set-ExecutionPolicy -ExecutionPolicy Unrestricted -Scope CurrentUser
  4. Clone this repository, e.g.:
    git clone https://github.com/JamesDBartlett3/ps-for-pbi ~\GitHub\ps-for-pbi
  5. Navigate to the folder where you cloned this repository, e.g.:
    cd ~\GitHub\ps-for-pbi\
  6. Unblock the scripts to make them executable on your system
    Unblock-File -Path .\*.ps1
  7. Run the script you want to use, e.g.:
    .\Export-PowerBIScannerApiData.ps1

Scripts

Admin, Governance, and Security

Canvas (.pbix) and Paginated (.rdl) Reports

  • Copy-PowerBIReportContentToBlankPBIXFile.ps1
    • Copies the content of a published Power BI canvas report to a blank .pbix file, then downloads it
    • Useful for downloading reports that cannot be downloaded from the Power BI service by conventional means for any number of reasons (e.g. the report was authored in a personal workspace, the semantic model was modified by XMLA endpoint, etc.)
  • Export-PowerBIReportsFromWorkspaces.ps1
    • Exports all Power BI canvas (.pbix) and paginated (.rdl) reports from all workspaces specified by the user, saves them in folders named after the workspaces they came from, and optionally extracts the .pbix files' source code using pbi-tools
    • TODO: Add support for exporting canvas reports as .pbip files (pending future support in either pbi-tools or the Power BI REST API)

Thin Models (Power BI semantic models without a corresponding report of the same name in the same workspace)

  • Get-PowerBIThinModelsFromWorkspaces.ps1
    • Finds all Thin Models to which the user has access and outputs the results as a PSObject with the following properties:
      • DatasetName
      • DatasetId
      • WorkspaceName
      • WorkspaceId
      • WebUrl
      • IsRefreshable
  • Export-PowerBIThinModelsFromWorkspaces.ps1
    • Exports all Thin Models specified by the user (as parameter values or piped input), and saves them in folders named after the workspaces they came from
    • TODO: Add ExportWithPbiTools switch parameter

Usage Metrics (It doesn't require Admin permission. You need to be the content owner.)

  • Get-UsageMetricsDataset.ps1
    • Return the ID of the hidden Usage Metric Semantic Model in the specified workspace; if that semantic model doesn't exist, it will create it.
    • TODO: Add DAX queries to download data from this dataset for further analysis.

Scorecards

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published