在多个PowerShell脚本之间传递CSV



我有一堆单独的脚本来构建基于Nessus每周扫描的各种报告。在每个脚本中,我执行如下操作:

Function Get-FileName($initialDirectory)
{
    [System.Reflection.Assembly]::LoadWithPartialName("System.windows.forms") | Out-Null
    $OpenFileDialog = New-Object System.Windows.Forms.OpenFileDialog
    $OpenFileDialog.initialDirectory = $initialDirectory
    $OpenFileDialog.filter = "csv (*.csv)| *.csv"
    $OpenFileDialog.ShowDialog() | Out-Null
    $OpenFileDialog.FileName
}
Clear-Host
# Get the scan CSV
$inputData = Get-FileName "C:users$env.usernameDownloads"
$data = Import-Csv $inputData 

从这里开始,我在单个脚本中做任何必要的工作。我想把它设置为抓取文件的位置然后在脚本之间传递CSV:

$data = Import-Csv $inputData 
#Call Installed Software script
". .Build Software List (Test).ps1 $data"
#Call Most Prolific Vulnerabilities
#This continues until I've called all scripts

我已经尝试了几种不同的方法来传递CSV,但都没有工作。有人能告诉我我错过了什么吗?

谢谢!

Build Software List (Test).ps1中,确保位置参数将接受输入:

param(
    [Parameter(Mandatory=$true,Position=0)]
    [psobject[]]$Data
)
# process items in $Data here

然后调用它:

& '.Build Software List (Test).ps1' $Data

如果您删除文件名中的空格,您可以取消调用操作符(&)和引号:

.Build-SoftwareList.ps1 $Data

我不认为你想在这里点源。

替换这一行:

#Call Installed Software script
". .Build Software List (Test).ps1 $data"

:

#Call Installed Software script
&  ".Build Software List (Test).ps1" $data

告诉powershell使用这些参数执行脚本,而不是将其作为当前运行脚本的一部分导入。

但是,即使您这样做了,它也会尝试将数据添加到参数列表中。由于$data是一个对象,而不是文件名,您可能想要使用管道:
$data | & ".Build Software List (Test).ps1"

相关内容

  • 没有找到相关文章

最新更新