Skip to content

Latest commit

 

History

History
74 lines (59 loc) · 1.71 KB

list-voices.md

File metadata and controls

74 lines (59 loc) · 1.71 KB

The list-voices.ps1 Script

This PowerShell script queries the installed text-to-speech (TTS) voices and prints them to the console.

Parameters

/home/markus/Repos/PowerShell/scripts/list-voices.ps1 [<CommonParameters>]

[<CommonParameters>]
    This script supports the common parameters: Verbose, Debug, ErrorAction, ErrorVariable, WarningAction, 
    WarningVariable, OutBuffer, PipelineVariable, and OutVariable.

Example

PS> ./list-voices.ps1



Name                     Culture  Gender     Age
----                     -------  ------     ---
Microsoft David Desktop  en-US      Male   Adult
...

Notes

Author: Markus Fleschutz | License: CC0

Related Links

https://github.com/fleschutz/PowerShell

Script Content

<#
.SYNOPSIS
	List installed text-to-speech voices
.DESCRIPTION
	This PowerShell script queries the installed text-to-speech (TTS) voices and prints them to the console.
.EXAMPLE
	PS> ./list-voices.ps1

	Name                     Culture  Gender     Age
	----                     -------  ------     ---
	Microsoft David Desktop  en-US      Male   Adult
	...
.LINK
	https://github.com/fleschutz/PowerShell
.NOTES
	Author: Markus Fleschutz | License: CC0
#>

#Requires -Version 2.0

try {
	Add-Type -AssemblyName System.Speech
	$Synth = New-Object System.Speech.Synthesis.SpeechSynthesizer
	$Synth.GetInstalledVoices() | 
		Select-Object -ExpandProperty VoiceInfo | 
		Select-Object -Property Name, Culture, Gender, Age
	exit 0 # success
} catch {
	"⚠️ Error in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])"
	exit 1
}

(generated by convert-ps2md.ps1 as of 11/20/2024 11:51:57)