1

我有以下功能:

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

我试过这样调用函数:

  1. "FromArgb(217,217,217)"
  2. 'FromArgb(217,217,217)'
  3. `"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)。

4

1 回答 1

2

要调用静态方法,请使用[TYPENAME]::MethodName(args).

所以做你想要的,使用这个:

[System.Drawing.Color]::FromArgb(217,217,217)
于 2013-04-24T20:15:43.387 回答