我尝试从c#运行powershell脚本。

首先,我将ExecutionPolicy设置为无限制,脚本现在从PowerShell ISE运行。

这是我的c#代码:

class Program
{
    private static PowerShell ps;
    static void Main(string[] args)
    {
        ps = PowerShell.Create();
        string ps1File = Path.Combine(Environment.CurrentDirectory, "script.ps1");
        ExecuteScript(ps1File);
        Console.ReadLine();
    }

    static void ExecuteScript(string script)
    {
        try
        {
            ps.AddScript(script);
            Collection<PSObject> results = ps.Invoke();
            Console.WriteLine("Output:");
            foreach (var psObject in results)
            {
                Console.WriteLine(psObject);
            }
            Console.WriteLine("Non-terminating errors:");
            foreach (ErrorRecord err in ps.Streams.Error)
            {
                Console.WriteLine(err.ToString());
            }
        }
        catch (RuntimeException ex)
        {
            Console.WriteLine("Terminating error:");
            Console.WriteLine(ex.Message);
        }
    }
}

输出为:

Ps1无法加载,因为在此上禁用了运行脚本 系统。要了解更多信息,请参阅about_Execution_Policies at http://go.microsoft.com/fwlink/?LinkID=135170。


当前回答

另一个解决方案是Remove ng。从C:\Users%username%\AppData\Roaming\npm\清空npm缓存

其他回答

最近,当我试图在netlify上部署一个应用程序时,我遇到了同样的问题:在这个系统上运行-scripts-is-disabled-on-this-system

下面cmd对我有用。

Set-ExecutionPolicy -ExecutionPolicy Bypass -Scope CurrentUser

我认为您可以在管理模式或命令提示符下使用powershell。

我得到这个错误:

 ng : File C:\Users\Nisha Jain\AppData\Roaming\npm\ng.ps1 cannot be loaded 
 because running scripts is disabled on this system. For more        
 information, see about_Execution_Policies at https:/go.microsoft.com/fwlink/? 
 LinkID=135170.
   At line:1 char:1
   + ng serve
   + ~~
    + CategoryInfo          : SecurityError: (:) [], PSSecurityException
    + FullyQualifiedErrorId : UnauthorizedAccess

只要删除这个文件ng.ps1

   Path is : C:\Users\username\AppData\Roaming\npm\ng.ps1

这对我来说很有效。

在管理模式下打开powershell 并执行以下命令

Set-ExecutionPolicy RemoteSigned

在终端(Visual Studio Code终端或您正在使用的任何IDE)中尝试此命令,问题将得到解决

Set-ExecutionPolicy -ExecutionPolicy Bypass -Scope CurrentUser

注意:不要把CurrentUser改成你的用户名