我有以下功能:
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
参数是 type [System.Drawing.Color]
。当我使用静态属性(Color-Cells -Color LightBlue
例如)调用该函数时,它只是查找。但是,当我尝试调用一个方法(Color-Cells -Color FromArgb(217,217,217)
例如)时,就会收到错误消息。有没有办法只将方法传递给函数?
根据迈克的回答,我可以成功地完全调用这样的函数:
Color-Cell -Range "A1" -Color $([System.Drawing.Color]::FromArgb(217,190,238))
但是,我想调用函数(使用方法)而不$()
在命令周围添加命令,也没有[System.Drawing.Color]::
像我可以只使用属性(例如 LightBlue)。