【发布时间】:2013-04-24 19:59:23
【问题描述】:
我有以下功能:
Function Color-Cells {
Param (
[Parameter(
Mandatory = $true,
Valuefrompipeline = $true)]
[String]$Range,
[Parameter(
Mandatory = $true)]
[System.Drawing.Color]$Color
)
$Global:WorkSheet.range($Range).Interior.color = $Color
}#End Function
我可以这样称呼:
Color-Cells -Range "A1" -Color LightBlue
没有任何问题。
我希望能够像这样调用函数:
Color-Cells -Range "A1" -Color FromArgb(217,217,217)
为了更精细地选择单元格的颜色,但是当我这样做时,我收到以下错误:
Color-Cells : Cannot process argument transformation on parameter 'Color'. Cannot convert value
"FromArgb(217,190,238)" to type "System.Drawing.Color". Error: "FromArgb(217 is not a valid value for Int32."
At line:70 char:32
+ Color-Cells -Range "A1" -Color "FromArgb(217,217,217)"
+ ~~~~~~~~~~~~~~~~~~~~~~~
+ CategoryInfo : InvalidData: (:) [Color-Cells], ParameterBindingArgumentTransformationException
+ FullyQualifiedErrorId : ParameterArgumentTransformationError,Color-Cells
我试过这样调用函数:
"FromArgb(217,217,217)"'FromArgb(217,217,217)'`"FromArgb(217,217,217)`"
而且它们都会产生错误。我对.Net不是很熟悉,所以我不确定如何解决这个问题。我的最终目标是创建一个函数,该函数可以根据 [System.drawing.color] 已知名称或 RGB 值为一系列单元格着色。
为清楚起见进行编辑:
TypeName 特定于函数中的参数类型。当我调用函数Color-cells 时,-Color 参数是[System.Drawing.Color] 类型。当我使用静态属性(例如Color-Cells -Color LightBlue)调用该函数时,它可以正常工作。但是,当我尝试调用一个方法(例如Color-Cells -Color FromArgb(217,217,217))时,就会收到错误消息。有没有办法只将方法传递给函数?
根据 Mike 的回答,我可以成功地完全调用这样的函数:
Color-Cell -Range "A1" -Color $([System.Drawing.Color]::FromArgb(217,190,238))
但是,我想调用函数(使用方法)而不在命令周围添加 $() 并且没有 [System.Drawing.Color]:: 就像我可以只使用属性(例如 LightBlue)。
【问题讨论】:
标签: function powershell system.drawing.color