PowerShell: RunSpace.SessionStateProxy.SetVariable не устанавливает переменную - PullRequest
1 голос
/ 06 октября 2011

ConsoleApplication:

class Program
{
    static void Main()
    {
        using (var runSpace = RunspaceFactory.CreateRunspace())
        {
            runSpace.Open();
            runSpace.SessionStateProxy.SetVariable("Var1", "Alex");
            using (var pipeline = runSpace.CreatePipeline("C:\\P.ps1"))
            {
                pipeline.Invoke();
            }
        }
    }
}

P.ps1

$logFile = "C:\MyLog.txt"

function Write-Log ([string] $message)
{
    Add-Content -Path $logFile -Value $message
}

Write-Log "Var1: " + $Var1

Я ожидаю, что "Var1: Alex" будет записано в мой файл журнала, но я получаю "Var1:".

Что я не так сделал?

Edit:

Моя первоначальная проблема на следующем сайте: http://nugetter.codeplex.com/workitem/31555

1 Ответ

4 голосов
/ 06 октября 2011

Из-за пробела в логе записи он видит их как несколько параметров.

Попробуйте это

Write-Log "Var1: $Var1"
...