Get-UptimeResult.ps1
19 Sep 2025Description
Purpose
Get-Uptime will extract the current system uptime from the computer entered.
Detailed Description
A detailed description of the Get-Uptime function.
Usage
Example 1
Get-Uptime
Example 2
Get-ADComputer -Filter { Name -like '*' } -Properties * | Where-Object -Property Name -NotLike '*AGAMAR*' | ForEach-Object -Process { Get-Uptime -ComputerName $_.Name } | Format-Table -AutoSize -Property Name,Days,Hours,Minutes
Example 3
'HOTH','KAMINO','DANTOOINE' | ForEach-Object -Process { Get-Uptime -ComputerName $_ } | Format-Table -AutoSize -Property Name,Days,Hours,Minutes
Notes
Additional information about the function.
Script
function Get-UptimeResult {
<#
.SYNOPSIS
Get-Uptime will extract the current system uptime from the computer entered.
.DESCRIPTION
A detailed description of the Get-Uptime function.
.PARAMETER ComputerName
Enter the Name/IP/FQDN for the computer you would like to retrieve the information from or pipe in a list of computers.
.PARAMETER Days
A description of the Days parameter.
.PARAMETER Since
A description of the Since parameter.
.EXAMPLE
Get-Uptime
.EXAMPLE
Get-ADComputer -Filter { Name -like '*' } -Properties * | Where-Object -Property Name -NotLike '*AGAMAR*' | ForEach-Object -Process { Get-Uptime -ComputerName $_.Name } | Format-Table -AutoSize -Property Name,Days,Hours,Minutes
.EXAMPLE
'HOTH','KAMINO','DANTOOINE' | ForEach-Object -Process { Get-Uptime -ComputerName $_ } | Format-Table -AutoSize -Property Name,Days,Hours,Minutes
.OUTPUTS
string
.NOTES
Additional information about the function.
#>
[CmdletBinding(DefaultParameterSetName = 'Default',
SupportsPaging = $true,
SupportsShouldProcess = $true)]
[OutputType([string], ParameterSetName = 'Default')]
param
(
# Enter the Name/IP/FQDN for the computer you would like to retrieve the information from or pipe in a list of computers.
[Parameter(ParameterSetName = 'Default',
Mandatory = $false,
ValueFromPipeline = $true,
ValueFromPipelineByPropertyName = $true,
ValueFromRemainingArguments = $true,
Position = 0,
HelpMessage = 'Enter the Name/IP/FQDN for the computer you would like to retrieve the information from or pipe in a list of computers.')]
[ValidateNotNullOrEmpty()]
[Alias('cn')]
[string[]]
$ComputerName = $env:COMPUTERNAME
)
begin {
}
process {
if ($PSCmdlet.ShouldProcess("$Computer", "Retrieving uptime")) {
foreach ($Computer in $ComputerName) {
$Date = (Get-CimInstance -ComputerName $Computer -Class Win32_OperatingSystem).LastBootUpTime
$TimeSpan = New-Timespan -Start $Date
try {
$properties = @{
'Name' = $Computer
'Date' = $Date
'Days' = $TimeSpan.Days
'Hours' = $TimeSpan.Hours
'Minutes' = $TimeSpan.Minutes
'Seconds' = $TimeSpan.Seconds
'Milliseconds' = $TimeSpan.Milliseconds
'Ticks' = $TimeSpan.Ticks
'TotalDays' = $TimeSpan.TotalDays
'TotalHours' = $TimeSpan.TotalHours
'TotalMinutes' = $TimeSpan.TotalMinutes
'TotalSeconds' = $TimeSpan.TotalSeconds
'TotalMilliseconds' = $TimeSpan.TotalMilliseconds
}
$obj = New-Object PSObject -Property $properties
Write-Output $obj
}
catch {
Write-Error -Message $_
}
}
}
}
end {
}
}
Download
Please feel free to copy parts of the script or if you would like to download the entire script, simply click the download button. You can download the complete repository in a zip file by clicking the Download link in the menu bar on the left hand side of the page.
Report Issues
You can report an issue or contribute to this site on GitHub. Simply click the button below and add any relevant notes. I will attempt to respond to all issues as soon as possible.