Reputation: 495
I have an excel vba code that finds a particular cell in a sheet. It uses the Find
method form the excel libraries. Here is the code
objRange.Find(What:="*", SearchDirection:=xlPrevious, SearchOrder:=xlByRows)
I need to do the same thing in powershell. But this method has a total of 9 arguments. How to ignore the other optional arguments in powershell. Something like this?
$range.Find("*", "", "", "", $xlByRows, $xlPrevious, "", "", "")
Here is the documentation of Range.Find
Method
Upvotes: 5
Views: 6196
Reputation: 753
I addressed this by creating overload methods that calls the core method with the value I want. e.g. I want the user to be able to specify the number of processed records or call the "Increment" method and then just call "WriteProgress" with no argument:
class UserFeedback {
[string]$Name
[int]$ThingCount
[datetime]$ProcessStartDateTime
[int]$ProcessedCount
UserFeedback ([string] $Name,[int]$ThingCount){
$this.ProcessStartDateTime = Get-Date
$this.Name = $Name
$this.ThingCount = $ThingCount
$this.ProcessedCount = 0
}
WriteProgress([int] $intProcessed){
$this.ProcessStartDateTime
$SecondsElapsed = ((Get-Date) - $this.ProcessStartDateTime).TotalSeconds
$SecondsRemaining = ($SecondsElapsed / ($intProcessed / $this.ThingCount)) - $SecondsElapsed
Write-Progress -Activity $this.Name -PercentComplete (($intProcessed/$($this.ThingCount)) * 100) -CurrentOperation "$("{0:N2}" -f ((($intProcessed/$($this.ThingCount)) * 100),2))% Complete" -SecondsRemaining $SecondsRemaining
}
WriteProgress(){
$this.WriteProgress($this.ProcessedCount)
}
Increment(){
$this.ProcessedCount ++
}
}
Upvotes: 1
Reputation: 200363
$null
doesn't work, but according to this answer you can use [Type]::Missing
:
$default = [Type]::Missing
$xl.Cells.Find("*", $default, $default, $default, $xlByRows, $xlPrevious,
$default, $default, $default)
Upvotes: 9