このサンプルでは、System.Management.Automation.PowerShell クラスを使用して、Get-Process を実行し、Sort-Object コマンドレットを同期的に する方法を示します。
Get-Process コマンドレットは、ローカル コンピューターで実行されている各プロセス System.Diagnostics.Process オブジェクトを返し、Sort-Object は System.Diagnostics.Process.Id* プロパティに基づいてオブジェクトを並べ替えます。 これらのコマンドの結果は、System.Windows.Forms.DataGridView コントロールを使用して表示されます。
必要条件
このサンプルには、Windows PowerShell 2.0 が必要です。
対象
このサンプルでは、次の例を示します。
コマンドを実行する System.Management.Automation.PowerShell オブジェクトを作成する。
System.Management.Automation.PowerShell オブジェクトのパイプラインにコマンドを追加します。
コマンドを同期的に実行する。
System.Windows.Forms.DataGridView コントロールを使用して、Windows フォーム アプリケーションでコマンドの出力を表示します。
例
このサンプルでは、Get-Process を実行し、Windows PowerShell で提供される既定の実行空間で Sort-Object コマンドレットを同期的に します。 出力は、System.Windows.Forms.DataGridView コントロールを使用してフォームに表示されます。
namespace Microsoft.Samples.PowerShell.Runspaces
{
using System;
using System.Collections;
using System.Collections.ObjectModel;
using System.Management.Automation;
using System.Management.Automation.Runspaces;
using System.Windows.Forms;
using PowerShell = System.Management.Automation.PowerShell;
/// <summary>
/// This class contains the Main entry point for this host application.
/// </summary>
internal class Runspace02
{
/// <summary>
/// This method creates the form where the output is displayed.
/// </summary>
private static void CreateForm()
{
Form form = new Form();
DataGridView grid = new DataGridView();
form.Controls.Add(grid);
grid.Dock = DockStyle.Fill;
// Create a PowerShell object. Creating this object takes care of
// building all of the other data structures needed to run the command.
using (PowerShell powershell = PowerShell.Create())
{
powershell.AddCommand("Get-Process").AddCommand("Sort-Object").AddArgument("ID");
if (Runspace.DefaultRunspace == null)
{
Runspace.DefaultRunspace = powershell.Runspace;
}
Collection<PSObject> results = powershell.Invoke();
// The generic collection needs to be re-wrapped in an ArrayList
// for data-binding to work.
ArrayList objects = new ArrayList();
objects.AddRange(results);
// The DataGridView will use the PSObjectTypeDescriptor type
// to retrieve the properties.
grid.DataSource = objects;
}
form.ShowDialog();
}
/// <summary>
/// This sample uses a PowerShell object to run the Get-Process
/// and Sort-Object cmdlets synchronously. Windows Forms and
/// data binding are then used to display the results in a
/// DataGridView control.
/// </summary>
/// <param name="args">The parameter is not used.</param>
/// <remarks>
/// This sample demonstrates the following:
/// 1. Creating a PowerShell object.
/// 2. Adding commands and arguments to the pipeline of
/// the PowerShell object.
/// 3. Running the commands synchronously.
/// 4. Using a DataGridView control to display the output
/// of the commands in a Windows Forms application.
/// </remarks>
private static void Main(string[] args)
{
Runspace02.CreateForm();
}
}
}
こちらもご覧ください
Windows PowerShell ホスト アプリケーション の作成の
PowerShell