如何将.cmd转换为PowerShell脚本?

时间:2015-02-10 13:19:02

标签: powershell batch-file branch

我有下一个文件(.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文件中

1 个答案:

答案 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我们创建另一个数组。然后可以单独处理该数组的每个元素。