我有下一个文件(.cmd):
@echo off
setlocal
for /f %%b in (Branches.txt) do (
set branches=%%b
)
call :parse "%branches%"
goto :eos
:parse
set branches=%1
set branches=%branches:"=%
for /f "tokens=1* delims=," %%a IN ("%branches%") DO (
if not "%%a" == "" call :sub %%a
if not "%%b" == "" call :parse "%%b"
)
goto :eos
:sub
echo Starting compilation for branch :[%1]
goto :eos
:eos
endlocal
其中" Branches.txt"包含这个:
branch1,branche2,branche3,...,branchn
该脚本从Branches.txt中获取最后一行,删除字符串中的所有引号,并在逗号上拆分该行。如果至少有一个元素,则使用第一个元素调用sub,如果该行在拆分时有两个或多个元素,则会在删除第一个元素的情况下重新解析该字符串。
我需要此代码,但需要在PowerShell .ps1文件中
答案 0 :(得分:3)
我认为这是你要找的东西的开始。请考虑以下txt文件branches.txt的内容。我引用了最后一行来表明他们正在被删除作为整个过程的一部分。
branch1,branche2,branche3
branch2,branche2,branche3
"branch3","branche2",branche3"
代码段
$path = "c:\temp\braches.txt"
$lastLine = Get-Content -Path $path | Select-Object -Last 1
$lastLine -replace '"' -split "," | ForEach-Object{
Write-Host "Do something with: $_"
}
将生成以下控制台输出。
Do something with: branch3
Do something with: branche2
Do something with: branche3
这将获取文件并将其内容作为字符串数组读取。我们采用最后一行并使用-replace
删除引号。然后使用-split
我们创建另一个数组。然后可以单独处理该数组的每个元素。