PowerShell uses the regional settings of Windows if the current date is queried via Get-Date
data:image/s3,"s3://crabby-images/621fe/621fe70a1d80610749e076db75493716b0d4b5d4" alt="PowerShell"
The settings can be checked with PowerShell via Get-Culture, and the detailed formats are shown in the Windows regional settings.
data:image/s3,"s3://crabby-images/405c8/405c89346ded72e3bdb2d0c48e850bf61a8119a3" alt="Local configuration for regional settings"
I would like to get a German name.
Get-Date -Format "dddd, dd.MM.yyyy" OR
Get-Date -Format "dddd, dd. MMMM yyyy"
The naming for weekday/month is not correct due to my English configuration
data:image/s3,"s3://crabby-images/0d56a/0d56ab2508ed6fa9861bcebd6ef0df7544e4b620" alt="PowerShell"
Instead of changing the regional settings, I can tell PowerShell which language it should use (once).
- For the weekday
$RegionalCulture = New-Object System.Globalization.CultureInfo("de-CH")
$DayName = $RegionalCulture.DateTimeFormat.GetDayName((Get-Date).DayOfWeek)
$Date = ("$DayName, " + (Get-Date -format "dd.MM.yyyy"))
$RegionalCulture.TextInfo.ToTitleCase($Date) # to capitalize the first character of the day
data:image/s3,"s3://crabby-images/faac8/faac823c9394e90fb3bd43d06396111e7ac725eb" alt="PowerShell"
- For weekday and month
PowerShell also adapts the month’s name to the German name with a bit of addition.
$RegionalCulture = New-Object System.Globalization.CultureInfo("de-CH")
$DayName = $RegionalCulture.DateTimeFormat.GetDayName((Get-Date).DayOfWeek)
$MonthName = $RegionalCulture.DateTimeFormat.GetMonthName(((Get-Date).Month))
$Date = ("$DayName, " + (Get-Date -format "dd. MMMMM yyyy")).Replace((Get-Date -format MMMM),$MonthName)
$RegionalCulture.TextInfo.ToTitleCase($Date) # to capitalize the first character of day and month
data:image/s3,"s3://crabby-images/5ab52/5ab528ad6467ef3bee896ff67391ae0ff76662e6" alt="PowerShell"
The option can be changed to many languages by customizing the language once. Microsoft lists the regional language codes here. It also supports Romansh for Switzerland.
$RegionalCulture = New-Object System.Globalization.CultureInfo("rm-CH")
$DayName = $RegionalCulture.DateTimeFormat.GetDayName((Get-Date).DayOfWeek)
$MonthName = $RegionalCulture.DateTimeFormat.GetMonthName(((Get-Date).Month))
$Date = ("$DayName, " + (Get-Date -format "dd. MMMMM yyyy")).Replace((Get-Date -format MMMM),$MonthName)
$RegionalCulture.TextInfo.ToTitleCase($Date) # to capitalize the first character of day and month
data:image/s3,"s3://crabby-images/9871f/9871f2ca782c778ef5aae89ea3a837af64e74ab3" alt="PowerShell"