我正在尝试从csv文件自动执行以下API调用。
http_uri
/ModuleName/api/12345/moverequest/MoveRequestQueue?batchSize=200
/ModuleName/api/Portal/[email protected]
/ModuleName/api/DeliveryDate/CommitEta?ref=H7J3M1EA4LF
/ModuleName/api/35345/moverequest/MoveRequestQueue?batchSize=500
输出应类似于csv文件中的以下内容。
ScenarioName Parameter Value
MoveRequestQueue batchSize 200
GetGarageLocations email [email protected]
CommitEta ref H7J3M1EA4LF
MoveRequestQueue batchSize 500
我正在使用下面的代码
$csv = Import-Csv C:\Powershell\Documents\Source.csv
$scenario = @()
ForEach ($row in $csv){
$httpuri = $($row.http_uri)
#Iterating through CSV rows and segregate values
if ($httpuri -match "="){
$equalarr = $httpuri -split '='
if ($equalarr[0] -match "\?"){
$questionarr = $equalarr[0] -split '\?'
$scenarionamearr = $questionarr[0] -split '/'
$totalelements = $scenarionamearr.Count
$scenarioname = $scenarionamearr[$totalelements-1]
$Scenario += $scenarioname
$Scenario += $questionarr[1]
$Scenario += $equalarr[1]
}
}
}
#Adding columns to csv
$columnName = '"Scenario","Parameter","Value"'
Add-Content -Path C:\Powershell\Documents\Output.csv -Value $columnName
#Writing values to CSV
$Scenario | foreach { Add-Content -Path C:\Powershell\Documents\Output.csv -Value $_ }
但是Outout如下生成
Scenario Parameter Value
DequeueMoveRequestQueue
batchSize
200
GetCarrierLocations
email
x-qldanxqldanx
由于我是新手,因此进行了大量搜索以解决此问题,但未能成功。请对此加以说明。
提前致谢....
如果将方案存储在结构化对象中,则可以使用Powershell的内置Export-Csv
命令来生成csv。
所以,代替
$Scenario += $scenarioname
$Scenario += $questionarr[1]
$Scenario += $equalarr[1]
存储Powershell对象数组:
$Scenario += [PSCustomObject]@{
"Scenario" = $scenarioname;
"Parameter" = $questionarr[1];
"Value" = $equalarr[1];}
然后,在创建csv文件时,只需使用Export-Csv
:
$Scenario | Export-Csv -NoTypeInformation -Path C:\Powershell\Documents\Output.csv
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句