我试图通过以下方式获得一个包含TestSuites和TCM.exe的特定TestPlan的列表:
$listOfSuites = & "C:\Program Files (x86)\Microsoft Visual Studio 12.0\Common7\IDE\TCM.exe" suites /list /planid:1234我得到了正确的结果,但是它被格式化为一个字符串,如下所示:
Id Name --------- ---------------------------------------------------------------- 1235 Test Project 1236 Test Project -> Manual Tests -> First TestSuite 1237 Test Project -> Manual Tests -> Second TestSuite是否有可能以列表或表的形式获得结果,以便我可以迭代这些套件?
问候约翰斯
发布于 2015-06-19 09:10:16
如果执行外部程序,则始终得到单个字符串。为了接收字符串表,首先调用
$listOfSuites.split("`r`n")若要获得字符串数组,则需要通过行填充字符串中的字符串偏移量来解析这些字符串(在您的示例中,0至9为"id",11结尾为"Name")。一个例子(取自这个剧本):
$starters = New-Object psobject -Property @{"SessionName" = 0; "Username" = 0;
"ID" = 0; "State" = 0; "Type" = 0; "Device" = 0;};
foreach($line in $c) {
if($line.trim().substring(0, $line.trim().indexof(" ")) -eq "SESSIONNAME") {
$starters.Username = $line.indexof("USERNAME");
$starters.ID = $line.indexof("ID");
$starters.State = $line.indexof("STATE");
$starters.Type = $line.indexof("TYPE");
$starters.Device = $line.indexof("DEVICE");
continue;
}
New-Object psobject -Property @{
"SessionName" = $line.trim().substring(0, $line.trim().indexof(" ")).trim(">")
;"Username" = $line.Substring($starters.Username, $line.IndexOf(" ", $starters.Username) - $starters.Username)
;"ID" = $line.Substring($line.IndexOf(" ", $starters.Username), $starters.ID - $line.IndexOf(" ", $starters.Username) + 2).trim()
;"State" = $line.Substring($starters.State, $line.IndexOf(" ", $starters.State)-$starters.State).trim()
;"Type" = $line.Substring($starters.Type, $starters.Device - $starters.Type).trim()
;"Device" = $line.Substring($starters.Device).trim()
} $c是一个外部命令的结果,该命令没有带有破折号的行和格式化为这种格式的头:
SESSIONNAME USERNAME ID STATE TYPE DEVICE一旦这样做,您就可以将每个字符串转换为一个New-Object PSObject -property @{"Id"=$parsedid;"Name"=$parsedname},并为自己提供一个定制对象列表以供使用。该技术在同一个例子中得到了演示。
https://stackoverflow.com/questions/30933922
复制相似问题