0

こんにちは、powershell を使用して入力ボックスを作成するスクリプトがあります。このように見えます

[void] [System.Reflection.Assembly]::LoadWithPartialName("System.Drawing") 
[void] [System.Reflection.Assembly]::LoadWithPartialName("System.Windows.Forms") 

$objForm = New-Object System.Windows.Forms.Form 
$objForm.Text = "Data Entry Form"
$objForm.Size = New-Object System.Drawing.Size(300,200) 
$objForm.StartPosition = "CenterScreen"

$objForm.KeyPreview = $True
$objForm.Add_KeyDown({if ($_.KeyCode -eq "Enter") 
{$x=$objTextBox.Text;$objForm.Close()}})
$objForm.Add_KeyDown({if ($_.KeyCode -eq "Escape") 
{$objForm.Close()}})

$OKButton = New-Object System.Windows.Forms.Button
$OKButton.Location = New-Object System.Drawing.Size(75,120)
$OKButton.Size = New-Object System.Drawing.Size(75,23)
$OKButton.Text = "OK"
$OKButton.Add_Click({$x=$objTextBox.Text;$objForm.Close()})
$objForm.Controls.Add($OKButton)

$CancelButton = New-Object System.Windows.Forms.Button
$CancelButton.Location = New-Object System.Drawing.Size(150,120)
$CancelButton.Size = New-Object System.Drawing.Size(75,23)
$CancelButton.Text = "Cancel"
$CancelButton.Add_Click({$objForm.Close()})
$objForm.Controls.Add($CancelButton)

$objLabel = New-Object System.Windows.Forms.Label
$objLabel.Location = New-Object System.Drawing.Size(10,20) 
$objLabel.Size = New-Object System.Drawing.Size(280,20) 
$objLabel.Text = "Please enter @from date:"
$objForm.Controls.Add($objLabel) 


$objTextBox = New-Object System.Windows.Forms.TextBox 
$objTextBox.Location = New-Object System.Drawing.Size(10,40) 
$objTextBox.Size = New-Object System.Drawing.Size(260,20) 
$objForm.Controls.Add($objTextBox) 

 $objForm.Topmost = $True

$objForm.Add_Shown({$objForm.Activate()})
[void] $objForm.ShowDialog()

$from

ここで、ストアド プロシージャ パラメータ @from に入力した値 $from を渡したいと思います。以下で試​​しましたが、機能しません。なにか提案を?

$SqlConnection = New-Object System.Data.SqlClient.SqlConnection
$SqlConnection.ConnectionString = "Server=localhost;Database=AMSDataWarehouse      Test;Integrated Security=SSPI"
$SqlCmd = New-Object System.Data.SqlClient.SqlCommand


 $SqlCmd.Connection = $SqlConnection
$SqlAdapter = New-Object System.Data.SqlClient.SqlDataAdapter
$SqlAdapter.SelectCommand = $SqlCmd
$SqlCmd.CommandText = "YQBreport1"
$cmd.Parameters.Add("@from", $from)| Out-Null
$Command.ExecuteNonQuery()
$from = $Command.Parameters["@from"].value


$DataSet = New-Object System.Data.DataSet
$SqlAdapter.Fill($DataSet)
$SqlConnection.Close()
$SQLResult =$DataSet.Tables[0]
$commands = $SQLResult | foreach-object -process { $_.output }> output.ps1
.\output.ps1
4

3 に答える 3

1

この線:

$OKButton.Add_Click({$x=$objTextBox.Text;$objForm.Close()})

機能内でのみAdd_click機能します。他の場所からアクセスできるようにするには、次のように少し変更する必要があります。

$OKButton.Add_Click({$Global:x=$objTextBox.Text;$objForm.Close()})

$xは、プロシージャに渡すことができるグローバル パラメータです。

于 2013-07-01T14:56:03.270 に答える
0

ええ、Windows Presentation Foundation(WPF)を使用してPowerShellでGUIを作成できます。私は試しましたが失敗しました。

次のような値を読み込みます。

$from = Read-Host '@From'
$from

Out-GridViewは、私が学んだばかりの新しいものです。あなたはそれを調べる必要があります。

ls | Out-GridView -PassThru -Title 'GUI?'
于 2013-03-08T09:03:39.723 に答える
0

PowerShell で入力ボックスを作成する方法の良い例 (Windows フォームを使用)

http://technet.microsoft.com/en-us/library/ff730941.aspx

于 2013-03-08T12:58:30.733 に答える