From 1a8fee6f94fe8b5fd0999f5e528ab5bfba95b6bc Mon Sep 17 00:00:00 2001 From: StartAutomating Date: Thu, 16 Oct 2025 12:36:23 -0700 Subject: [PATCH 1/2] fix: Get-OpenXML improvement ( Fixes #2 ) Using .GetParts to check document type --- Commands/Get-OpenXML.ps1 | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/Commands/Get-OpenXML.ps1 b/Commands/Get-OpenXML.ps1 index 735371c..104e824 100644 --- a/Commands/Get-OpenXML.ps1 +++ b/Commands/Get-OpenXML.ps1 @@ -18,7 +18,7 @@ function Get-OpenXML [Alias('OpenXML')] param( # The path to the OpenXML file to read - [Parameter(ValueFromPipelineByPropertyName=$true)] + [Parameter(ValueFromPipelineByPropertyName)] [Alias('Fullname')] [string] $FilePath @@ -46,33 +46,34 @@ function Get-OpenXML $filePackage.pstypenames.insert(0,'OpenXML') $filePackage.pstypenames.insert(0,'OpenXML.File') - $packageContent = $filePackage.Parts $openXMLObject = $filePackage | Add-Member NoteProperty FilePath $filePath -Force -PassThru | Add-Member NoteProperty MemoryStream $memoryStream -Force -PassThru + + $packageParts = $filePackage.GetParts() # Now we can get more specific about what type of OpenXML file this is. # By looking for certain key parts, we can determine if this is a PowerPoint, Excel, or Word file. # For example, if the package contains a part with `/ppt/` in the URI, - if ($filePackage.Parts.Keys -match '/ppt/') { + if ($packageParts.Uri -match '^/ppt/') { # it is an `OpenXML.PowerPoint.File` $openXmlObject.pstypenames.insert(0, 'OpenXML.PowerPoint.File') } # If the package contains a part with `/xl/` in the URI, - if ($filePackage.Parts.Keys -match '/xl/') { + if ($packageParts.Uri -match '^/xl/') { # it is an `OpenXML.Excel.File` $openXmlObject.pstypenames.insert(0, 'OpenXML.Excel.File') } # If the package contains a part with `/word/` in the URI, it is a Word file. - if ($filePackage.Parts.Keys -match '/word/') { + if ($packageParts.Uri -match '^/word/') { # it is an `OpenXML.Word.File` $openXmlObject.pstypenames.insert(0, 'OpenXML.Word.File') } # If the package contains a part with `/Documents/` in the URI, - if ($filePackage.Parts.Keys -match '/Documents/') { + if ($packageParts.Uri -match '^Documents/') { # it is an `OpenXML.XPS.File` $openXmlObject.pstypenames.insert(0, 'OpenXML.XPS.File') } From 62d8683eb2c76f8bd343c067d0a32ba974b91c5c Mon Sep 17 00:00:00 2001 From: StartAutomating Date: Thu, 16 Oct 2025 12:38:28 -0700 Subject: [PATCH 2/2] fix: Updating manifest and README ( Fixes #1 ) --- OpenXML.psd1 | 2 +- README.md | 5 +++++ README.md.ps1 | 8 ++++++++ 3 files changed, 14 insertions(+), 1 deletion(-) diff --git a/OpenXML.psd1 b/OpenXML.psd1 index b6cfc54..f093eec 100644 --- a/OpenXML.psd1 +++ b/OpenXML.psd1 @@ -42,7 +42,7 @@ PrivateData = @{ PSData = @{ # Tags applied to this module. These help with module discovery in online galleries. - Tags = @('Word','Excel','PowerPoint','OpenXML','Office Open XML','OOXML') + Tags = @('Word','Excel','PowerPoint','OpenXML','OfficeOpenXML','OOXML') # A URL to the license for this module. LicenseUri = 'https://github.com/PowerShellWeb/OpenXML/blob/main/LICENSE' diff --git a/README.md b/README.md index a3377ca..d562ea7 100644 --- a/README.md +++ b/README.md @@ -1,5 +1,10 @@ # OpenXML ## Automate OpenXML. Excel, Word, and PowerPoint automation in PowerShell. +
+ + + +
OpenXML is the standard used for Office documents. diff --git a/README.md.ps1 b/README.md.ps1 index a4bc6cf..083d90b 100644 --- a/README.md.ps1 +++ b/README.md.ps1 @@ -26,6 +26,14 @@ This module is here to help you automate, inspect, and understand OpenXML files. "## $($ThisModule.Description)" +@" +
+ + + +
+"@ + $intro "### Installing and Importing"