Added comment-based help

This commit is contained in:
Markus Fleschutz 2020-12-29 14:14:21 +00:00
parent 3b83d94809
commit 66bc6a7699
85 changed files with 687 additions and 725 deletions

View File

@ -136,7 +136,7 @@ Using PowerShell in Context Menus
Script Conventions Script Conventions
------------------ ------------------
Each PowerShell script should follow the 8 golden rules: Each PowerShell script should follow the 9 golden rules:
* **Rule #1:** the filename should be named `<verb>-<object>.ps1` * **Rule #1:** the filename should be named `<verb>-<object>.ps1`
* **Rule #2:** the first line reads `#!/snap/bin/powershell` to support PowerShell on Linux * **Rule #2:** the first line reads `#!/snap/bin/powershell` to support PowerShell on Linux
@ -145,7 +145,8 @@ Each PowerShell script should follow the 8 golden rules:
* **Rule #5:** prefer command-line options, else ask the user * **Rule #5:** prefer command-line options, else ask the user
* **Rule #6:** the encoding of the script is in UTF-8 with BOM to support Unicode characters * **Rule #6:** the encoding of the script is in UTF-8 with BOM to support Unicode characters
* **Rule #7:** use `Set-StrictMode -Version Latest` to enable additional error checking * **Rule #7:** use `Set-StrictMode -Version Latest` to enable additional error checking
* **Rule #8:** exits 0 for success, else print an error message and exit with the error code (mostly 1) * **Rule #8:** for readibility use lowercase or lowerCamelCase
* **Rule #9:** exits 0 for success, else print an error message and exit with the error code (mostly 1)
Feedback Feedback
-------- --------

View File

@ -1,12 +1,13 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./MD5.ps1 [<file>] .SYNTAX ./MD5.ps1 [<file>]
# Description: prints the MD5 checksum of the given file .DESCRIPTION prints the MD5 checksum of the given file
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([string]$File) param([string]$File)
try { try {
if ($File -eq "" ) { if ($File -eq "" ) {
$File = read-host "Enter path to file" $File = read-host "Enter path to file"

View File

@ -1,12 +1,13 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./SHA1.ps1 [<file>] .SYNTAX ./SHA1.ps1 [<file>]
# Description: prints the SHA1 checksum of the given file .DESCRIPTION prints the SHA1 checksum of the given file
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([string]$File) param([string]$File)
try { try {
if ($File -eq "" ) { if ($File -eq "" ) {
$File = read-host "Enter file" $File = read-host "Enter file"

View File

@ -1,12 +1,13 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./SHA256.ps1 [<file>] .SYNTAX ./SHA256.ps1 [<file>]
# Description: prints the SHA256 checksum of the given file .DESCRIPTION prints the SHA256 checksum of the given file
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([string]$File) param([string]$File)
try { try {
if ($File -eq "" ) { if ($File -eq "" ) {
$File = read-host "Enter file" $File = read-host "Enter file"

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./alert.ps1 [<message>] .SYNTAX ./alert.ps1 [<message>]
# Description: handle and escalate the given alert message .DESCRIPTION handle and escalate the given alert message
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([string]$Message) param([string]$Message)
if ($Message -eq "" ) { if ($Message -eq "" ) {

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./calculator.ps1 .SYNTAX ./calculator.ps1
# Description: starts a calculator (GUI) .DESCRIPTION starts a calculator (GUI)
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
clear-host clear-host
write-host " PowerShell Calculator " -for green write-host " PowerShell Calculator " -for green

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./check-ipv4-address.ps1 [<address>] .SYNTAX ./check-ipv4-address.ps1 [<address>]
# Description: checks the given IPv4 address for validity .DESCRIPTION checks the given IPv4 address for validity
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([string]$Addr) param([string]$Addr)

View File

@ -1,7 +1,11 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./check-mac-address.ps1 [<MAC>]
.DESCRIPTION checks the given MAC address for validity
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./check-mac-address.ps1 [<MAC>]
# Description: checks the given MAC address for validity
# Author: Markus Fleschutz # Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell # Source: github.com/fleschutz/PowerShell
# License: CC0 # License: CC0

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./check-xml-file [<file>] .SYNTAX ./check-xml-file [<file>]
# Description: checks the given XML file for validity .DESCRIPTION checks the given XML file for validity
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param ([String]$XmlFilePath) param ([String]$XmlFilePath)

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./clone-repos.ps1 .SYNTAX ./clone-repos.ps1
# Description: clones well-known Git repositories into the current directory. .DESCRIPTION clones well-known Git repositories into the current directory.
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
$Repos = "https://github.com/commonmark/cmark", "https://github.com/opencv/opencv", "https://github.com/openzfs/zfs", "https://github.com/synesthesiam/voice2json", "https://github.com/fleschutz/CWTS", "https://github.com/fleschutz/cubesum", "https://github.com/fleschutz/PowerShell","https://github.com/fleschutz/CWTS", "https://github.com/fleschutz/eventdriven" $Repos = "https://github.com/commonmark/cmark", "https://github.com/opencv/opencv", "https://github.com/openzfs/zfs", "https://github.com/synesthesiam/voice2json", "https://github.com/fleschutz/CWTS", "https://github.com/fleschutz/cubesum", "https://github.com/fleschutz/PowerShell","https://github.com/fleschutz/CWTS", "https://github.com/fleschutz/eventdriven"

View File

@ -1,9 +1,9 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./close-chrome.ps1 .SYNTAX ./close-chrome.ps1
# Description: closes Google Chrome gracefully .DESCRIPTION closes Google Chrome gracefully
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
./close-program "chrome" ./close-program "chrome"

View File

@ -1,9 +1,9 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./close-edge.ps1 .SYNTAX ./close-edge.ps1
# Description: closes Microsoft Edge gracefully .DESCRIPTION closes Microsoft Edge gracefully
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
./close-program "msedge" ./close-program "msedge"

View File

@ -1,9 +1,9 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./close-file-explorer.ps1 .SYNTAX ./close-file-explorer.ps1
# Description: closes Microsoft File Explorer gracefully .DESCRIPTION closes Microsoft File Explorer gracefully
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
./close-program "explorer" ./close-program "explorer"

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./close-program.ps1 [<program-name>] .SYNTAX ./close-program.ps1 [<program-name>]
# Description: closes the given program gracefully .DESCRIPTION closes the given program gracefully
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([string]$ProgramName) param([string]$ProgramName)

View File

@ -1,9 +1,9 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./close-thunderbird.ps1 .SYNTAX ./close-thunderbird.ps1
# Description: closes Mozilla Thunderbird gracefully .DESCRIPTION closes Mozilla Thunderbird gracefully
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
./close-program "thunderbird" ./close-program "thunderbird"

View File

@ -1,9 +1,9 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./close-windows-terminal.ps1 .SYNTAX ./close-windows-terminal.ps1
# Description: closes Windows Terminal gracefully .DESCRIPTION closes Windows Terminal gracefully
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
./close-program "WindowsTerminal" ./close-program "WindowsTerminal"

View File

@ -1,11 +1,11 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./configure-git.ps1 .SYNTAX ./configure-git.ps1
# Description: sets up the Git configuration .DESCRIPTION sets up the Git configuration
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 requires installation of Git
# NOTE: requires installation of Git #>
$UserName = read-host "Enter your full name" $UserName = read-host "Enter your full name"
$UserEmail = read-host "Enter your email address" $UserEmail = read-host "Enter your email address"

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./csv-to-text.ps1 [<csv-file>] .SYNTAX ./csv-to-text.ps1 [<csv-file>]
# Description: converts the given CSV file into a text list .DESCRIPTION converts the given CSV file into a text list
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([String]$Path) param([String]$Path)

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./display-time.ps1 .SYNTAX ./display-time.ps1
# Description: displays the current time .DESCRIPTION displays the current time
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
try { try {
for ($i = 0; $i -lt 1000; $i++) { for ($i = 0; $i -lt 1000; $i++) {

View File

@ -1,9 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: empty-dir.ps1 <dir> .SYNTAX ./empty-dir.ps1 [<path-to-dir>]
# Description: Empties the given directory. The content is removed! .DESCRIPTION Empties the given directory by removing(!) any file and subdirectories.
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# License: CC0 .NOTES Author: Markus Fleschutz / License: CC0
#>
# TODO # TODO
exit 0 exit 0

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./enable-crash-dumps.ps1 .SYNTAX ./enable-crash-dumps.ps1
# Description: enables the writing of crash dumps .DESCRIPTION enables the writing of crash dumps
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
################################################################## ##################################################################
# # # #

View File

@ -1,18 +1,18 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./inspect-exe.ps1 [<path-to-exe-file>]
.DESCRIPTION prints basic information of the given executable file
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./inspect-exe.ps1 [<executable-file>] param([string]$PathToExe)
# Description: prints basic information of the given executable file
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
param([string]$File)
try { try {
if ($File -eq "" ) { if ($PathToExe -eq "" ) {
$File = read-host "Enter path to executable file" $PathToExe = read-host "Enter path to executable file"
} }
get-childitem $File | % {$_.VersionInfo} | Select * get-childitem $PathToExe | % {$_.VersionInfo} | Select *
exit 0 exit 0
} catch { } catch {
write-error "ERROR in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])" write-error "ERROR in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])"

View File

@ -1,15 +1,14 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./list-anagrams.ps1 [<word>] [<columns>]
.DESCRIPTION lists all anagrams of the given word
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./list-anagrams.ps1 [<word>] param([string]$Word, [int]$Columns = 8)
# Description: lists all anagrams of the given word
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
param([string]$Word) function GetPermutations {
$Columns = 8
Function GetPermutations {
[cmdletbinding()] [cmdletbinding()]
Param( Param(
[parameter(ValueFromPipeline=$True)] [parameter(ValueFromPipeline=$True)]

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./list-cmdlets.ps1 .SYNTAX ./list-cmdlets.ps1
# Description: lists all PowerShell cmdlets .DESCRIPTION lists all PowerShell cmdlets
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
try { try {
Get-Command -Command-Type cmdlet Get-Command -Command-Type cmdlet

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./list-earthquakes.ps1 .SYNTAX ./list-earthquakes.ps1
# Description: lists earthquakes >= 6.0 for the last 30 days .DESCRIPTION lists earthquakes with magnitude >= 6.0 for the last 30 days
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
$Format="csv" # csv, geojson, kml, text, xml $Format="csv" # csv, geojson, kml, text, xml
$MinMagnitude=6.0 $MinMagnitude=6.0

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./list-empty-dirs.ps1 <dirtree> .SYNTAX ./list-empty-dirs.ps1 <dirtree>
# Description: lists empty subfolders in the <directory tree> .DESCRIPTION lists empty subfolders in the <directory tree>
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([string]$DirTree) param([string]$DirTree)

View File

@ -1,16 +1,16 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./list-files.ps1 [<folder>] .SYNTAX ./list-files.ps1 [<folder>]
# Description: lists all files in the given <folder> and also in every subfolder .DESCRIPTION lists all files in the given folder and also in every subfolder
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([string]$Folder) param([string]$Folder)
try { try {
if ($Folder -eq "" ) { if ($Folder -eq "" ) {
[String]$Folder = read-host "Enter path to folder" [string]$Folder = read-host "Enter path to folder"
} }
Get-ChildItem -path $Folder -recurse | select FullName Get-ChildItem -path $Folder -recurse | select FullName
exit 0 exit 0

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./list-logbook.ps1 .SYNTAX ./list-logbook.ps1
# Description: lists the content of the logbook (../Data/Logbook.csv) .DESCRIPTION lists the content of the logbook (../Data/Logbook.csv)
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
try { try {
$PathToRepo=(get-item $MyInvocation.MyCommand.Path).directory.parent $PathToRepo=(get-item $MyInvocation.MyCommand.Path).directory.parent

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./list-modules.ps1 .SYNTAX ./list-modules.ps1
# Description: lists all PowerShell modules .DESCRIPTION lists all PowerShell modules
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
try { try {
Get-Module Get-Module

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./list-processes.ps1 .SYNTAX ./list-processes.ps1
# Description: lists the local computer processes .DESCRIPTION lists the local computer processes
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
try { try {
Get-Process | Format-Table -Property Id, @{Label="CPU(s)";Expression={$_.CPU.ToString("N")+"%"};Alignment="Right"}, ProcessName -AutoSize Get-Process | Format-Table -Property Id, @{Label="CPU(s)";Expression={$_.CPU.ToString("N")+"%"};Alignment="Right"}, ProcessName -AutoSize

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./list-random-passwords.ps1 .SYNTAX ./list-random-passwords.ps1
# Description: prints a list of random passwords .DESCRIPTION prints a list of random passwords
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
$PasswordLength = 15 $PasswordLength = 15
$Columns = 6 $Columns = 6

View File

@ -1,18 +1,16 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./list-random-pins.ps1 [<pin-length>] [<columns>] [<rows>]
.DESCRIPTION prints a list of random PIN's
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./list-random-pins.ps1 param([int]$PinLength = 5, [int]$Columns = 12, [int]$Rows = 24)
# Description: prints a list of random PIN's
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
$PIN_Length = 5
$Columns = 12
$Lines = 24
function GeneratePIN() { function GeneratePIN() {
$Generator = New-Object System.Random $Generator = New-Object System.Random
for ($i = 0; $i -lt $PIN_Length; $i++) { for ($i = 0; $i -lt $PinLength; $i++) {
$PIN += [char]$Generator.next(48,57) $PIN += [char]$Generator.next(48,57)
} }
return $PIN return $PIN
@ -20,7 +18,7 @@ function GeneratePIN() {
try { try {
write-output "" write-output ""
for ($j = 0; $j -lt $Lines; $j++) { for ($j = 0; $j -lt $Rows; $j++) {
$Line = "" $Line = ""
for ($k = 0; $k -lt $Columns; $k++) { for ($k = 0; $k -lt $Columns; $k++) {
$Line += GeneratePIN $Line += GeneratePIN

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./list-unused-files.ps1 <dirtree> <days> .SYNTAX ./list-unused-files.ps1 <dirtree> <days>
# Description: lists files in the <directory tree> with last access time older than <days> .DESCRIPTION lists files in the <directory tree> with last access time older than <days>
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([string]$DirTree, [int]$NumberOfDaysUnused) param([string]$DirTree, [int]$NumberOfDaysUnused)

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./locate-city.ps1 [<city>] .SYNTAX ./locate-city.ps1 [<city>]
# Description: prints the geographic location of the given city .DESCRIPTION prints the geographic location of the given city
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([string]$City) param([string]$City)
if ($City -eq "" ) { if ($City -eq "" ) {

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./locate-ipaddress.ps1 [<IPaddress>] .SYNTAX ./locate-ipaddress.ps1 [<IPaddress>]
# Description: prints the geographic location of the given IP address .DESCRIPTION prints the geographic location of the given IP address
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([string]$IPaddr) param([string]$IPaddr)
try { try {

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./locate-zip-code.ps1 [<country-code>] [<zip-code>] .SYNTAX ./locate-zip-code.ps1 [<country-code>] [<zip-code>]
# Description: prints the geographic location of the given zip-code .DESCRIPTION prints the geographic location of the given zip-code
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([string]$CountryCode, [string]$ZipCode) param([string]$CountryCode, [string]$ZipCode)

View File

@ -1,9 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: make-install.ps1 <build-dir> .SYNTAX make-install.ps1 <build-dir>
# Description: Copies newer EXE's + DLL's from the build directory to the installation directory. .DESCRIPTION Copies newer EXE's + DLL's from the build directory to the installation directory.
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# License: CC0 .NOTES Author: Markus Fleschutz / License: CC0
#>
set SRC_DIR=%1 set SRC_DIR=%1
set "DST_DIR=C:\Program Files\MyApp\bin" set "DST_DIR=C:\Program Files\MyApp\bin"

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./moon.ps1 .SYNTAX ./moon.ps1
# Description: prints the current moon phase .DESCRIPTION prints the current moon phase
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
try { try {
(Invoke-WebRequest http://wttr.in/Moon -UserAgent "curl" ).Content (Invoke-WebRequest http://wttr.in/Moon -UserAgent "curl" ).Content

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./mute-audio.ps1 .SYNTAX ./mute-audio.ps1
# Description: mutes the audio .DESCRIPTION mutes the audio
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
try { try {
$obj = new-object -com wscript.shell $obj = new-object -com wscript.shell

View File

@ -1,17 +1,18 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./new-email.ps1 [<address>]
.DESCRIPTION starts the default email client to write a new email
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./new-email.ps1 [<address>] param([string]$EmailAddress)
# Description: starts the default email client to write a new email
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
param([string]$emailAddress)
try { try {
if ($emailAddress -eq "" ) { if ($EmailAddress -eq "" ) {
$emailAddress = "markus@fleschutz.de" $EmailAddress = "markus@fleschutz.de"
} }
$URL="mailto:$emailAddress" $URL="mailto:$EmailAddress"
Start-Process $URL Start-Process $URL
exit 0 exit 0
} catch { } catch {

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./news.ps1 .SYNTAX ./news.ps1
# Description: print the latest news .DESCRIPTION print the latest news
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
#$RSS_URL = "http://feeds.skynews.com/feeds/rss/world.xml" #$RSS_URL = "http://feeds.skynews.com/feeds/rss/world.xml"
$RSS_URL = "https://yahoo.com/news/rss/world" $RSS_URL = "https://yahoo.com/news/rss/world"

View File

@ -1,12 +1,13 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./open-browser.ps1 [<URL>] .SYNTAX ./open-browser.ps1 [<URL>]
# Description: starts the default Web browser, optional with given URL .DESCRIPTION starts the default Web browser, optional with given URL
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([string]$URL) param([string]$URL)
try { try {
if ($URL -eq "" ) { if ($URL -eq "" ) {
$URL = "http://www.fleschutz.de" $URL = "http://www.fleschutz.de"

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./open-email-client.ps1 .SYNTAX ./open-email-client.ps1
# Description: starts the default email client .DESCRIPTION starts the default email client
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
try { try {
Start-Process "mailto:markus@fleschutz.de" Start-Process "mailto:markus@fleschutz.de"

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./play-beep.ps1 .SYNTAX ./play-beep.ps1
# Description: plays a beep sound .DESCRIPTION plays a beep sound
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
try { try {
[console]::beep(500,300) [console]::beep(500,300)

View File

@ -1,12 +1,13 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./poweroff.ps1 .SYNTAX ./poweroff.ps1
# Description: halts the local computer, administrator rights are required .DESCRIPTION halts the local computer, administrator rights are required
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
#Requires -RunAsAdministrator #Requires -RunAsAdministrator
try { try {
Stop-Computer Stop-Computer
exit 0 exit 0

View File

@ -1,12 +1,13 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./reboot.ps1 .SYNTAX ./reboot.ps1
# Description: reboots the local computer, administrator rights are required .DESCRIPTION reboots the local computer, administrator rights are required
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
#Requires -RunAsAdministrator #Requires -RunAsAdministrator
try { try {
Restart-Computer Restart-Computer
exit 0 exit 0

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./scan-ports.ps1 .SYNTAX ./scan-ports.ps1
# Description: scans the network for open/closed ports .DESCRIPTION scans the network for open/closed ports
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
$network = "192.168.178" $network = "192.168.178"
$port = 8080 $port = 8080

View File

@ -1,12 +1,12 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./search-files.ps1 [<pattern>] [<path>]
.DESCRIPTION searches the given pattern in the given files
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./search-files.ps1 [<pattern>] [<path>] param([string]$Pattern, [string]$Path)
# Description: searches the given pattern in the given files
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
param([String]$Pattern, [String]$Path)
Set-StrictMode -Version Latest Set-StrictMode -Version Latest

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./send-email.ps1 .SYNTAX ./send-email.ps1
# Description: sends an email .DESCRIPTION sends an email
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
$smtpServer = "smtp.example.com" $smtpServer = "smtp.example.com"
$From = read-host "Enter sender email address" $From = read-host "Enter sender email address"

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./send-tcp.ps1 [<IP>] [<port>] [<message>] .SYNTAX ./send-tcp.ps1 [<target-IP>] [<target-port>] [<message>]
# Description: sends a TCP message to the given IP address and port .DESCRIPTION sends a TCP message to the given IP address and port
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([string]$TargetIP, [int]$TargetPort, [string]$Message) param([string]$TargetIP, [int]$TargetPort, [string]$Message)

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./send-udp.ps1 [<IP>] [<port>] [<message>] .SYNTAX ./send-udp.ps1 [<target-IP>] [<target-port>] [<message>]
# Description: sends a UDP datagram message to the given IP address and port .DESCRIPTION sends a UDP datagram message to the given IP address and port
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([string]$TargetIP, [int]$TargetPort, [string]$Message) param([string]$TargetIP, [int]$TargetPort, [string]$Message)

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./set-timer.ps1 [<seconds>] .SYNTAX ./set-timer.ps1 [<seconds>]
# Description: sets a timer for a countdown .DESCRIPTION sets a timer for a countdown
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([int]$Seconds) param([int]$Seconds)
try { try {

View File

@ -1,48 +1,48 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./simulate-matrix.ps1 .SYNTAX ./simulate-matrix.ps1
# Description: simulates the Matrix (fun) .DESCRIPTION simulates the Matrix (fun)
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
try { try {
write-progress "Reading Matrix.csv..." write-progress "Reading Matrix.csv..."
$PathToRepo=(get-item $MyInvocation.MyCommand.Path).directory.parent $PathToRepo=(get-item $MyInvocation.MyCommand.Path).directory.parent
$Table = import-csv "$PathToRepo/Data/Matrix.csv" $Table = import-csv "$PathToRepo/Data/Matrix.csv"
Clear-Host clear-host
foreach($Row in $Table) { foreach($Row in $Table) {
for ($i = 0; $i -lt 4; $i++) { for ($i = 0; $i -lt 4; $i++) {
Write-Host -nonewline $($Row.A); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.A); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.B); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.B); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.C); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.C); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.D); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.D); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.E); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.E); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.F); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.F); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.G); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.G); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.H); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.H); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.I); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.I); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.J); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.J); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.K); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.K); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.L); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.L); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.M); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.M); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.N); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.N); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.O); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.O); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.P); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.P); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.Q); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.Q); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.R); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.R); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.S); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.S); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.T); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.T); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.U); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.U); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.V); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.V); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.W); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.W); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.X); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.X); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.Y); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.Y); start-sleep -milliseconds 5
Write-Host -nonewline $($Row.Z); Start-Sleep -milliseconds 5 write-host -nonewline $($Row.Z); start-sleep -milliseconds 5
} }
Write-Host "" write-host ""
Start-Sleep -milliseconds 200 start-sleep -milliseconds 200
} }
exit 0 exit 0
} catch { } catch {

View File

@ -1,19 +1,17 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./simulate-presence.ps1 [<IP-address>]
.DESCRIPTION simulates the human presence against burglars
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./simulate-presence.ps1 param([string]IPaddress)
# Description: simulates the human presence against burglars
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
function SwitchLight { for ([int]$i = 0; $i -lt 1000; $i++) {
./switch-shelly1 $IPaddress on 0
sleep 60
./switch-shelly1 $IPaddress off 0
sleep 10
} }
SwitchLight 1
sleep 60
SwitchLight 0
sleep 10
exit 0 exit 0

View File

@ -1,12 +1,13 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./speak-file.ps1 [<file>] .SYNTAX ./speak-file.ps1 [<file>]
# Description: speaks the content of the given text file by text-to-speech (TTS) .DESCRIPTION speaks the content of the given text file by text-to-speech (TTS)
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([string]$File) param([string]$File)
try { try {
if ($File -eq "") { if ($File -eq "") {
$File = read-host "Enter path to file" $File = read-host "Enter path to file"

View File

@ -1,12 +1,13 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./speak-text.ps1 [<text>] .SYNTAX ./speak-text.ps1 [<text>]
# Description: speaks the given text by text-to-speech (TTS) .DESCRIPTION speaks the given text by text-to-speech (TTS)
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([string]$Text) param([string]$Text)
try { try {
if ($Text -eq "") { if ($Text -eq "") {
$Text = read-host "Enter text to speak" $Text = read-host "Enter text to speak"

View File

@ -1,21 +1,21 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./switch-shelly1.ps1 [<IP-address>] [<turn-mode>] [<timer>]
.DESCRIPTION switches a Shelly1 device in the local network
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./switch-shelly1.ps1 [<IP addr>] [<turn-mode>] [<timer>] param([string]$IPaddr, [string]$TurnMode, [int]$Timer = -999)
# Description: switches a Shelly1 device in the local network
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
param([String]$IPaddr, [String]$TurnMode, [Int]$Timer)
try { try {
if ($IPaddr -eq "" ) { if ($IPaddr -eq "") {
[String]$IPaddr = read-host "Enter IP address of the Shelly1 device" [String]$IPaddr = read-host "Enter IP address of the Shelly1 device"
} }
if ($TurnMode -eq "" ) { if ($TurnMode -eq "") {
[String]$TurnMode = read-host "Enter turn mode (on/off/toggle)" [String]$TurnMode = read-host "Enter turn mode (on/off/toggle)"
} }
if ($Timer -eq 0 ) { if ($Timer -eq -999) {
[Int]$Timer = read-host "Enter timer (0=endless)" [Int]$Timer = read-host "Enter timer (0=endless)"
} }

View File

@ -1,38 +1,12 @@
#!/snap/bin/powershell #!/snap/bin/powershell
Function Get-TimedScreenshot {
<# <#
.SYNOPSIS .SYNTAX ./take-screenshot.ps1
.DESCRIPTION takes a single screenshots
Get-TimedScreenshot .LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
.DESCRIPTION
A function that takes screenshots and saves them to a folder.
.PARAMETER $Path
Specifies the folder path.
.PARAMETER $Interval
Specifies the interval in seconds between taking screenshots.
.PARAMETER $EndTime
Specifies when the script should stop running in the format HH-MM
.EXAMPLE
PS C:\> Get-TimedScreenshot -Path c:\temp\ -Interval 30 -EndTime 14:00
.LINK
http://obscuresecurity.blogspot.com/2013/01/Get-TimedScreenshot.html
https://github.com/obscuresec/random/blob/master/Get-TimedScreenshot
#> #>
Function Get-TimedScreenshot {
[CmdletBinding()] Param( [CmdletBinding()] Param(
[Parameter(Mandatory=$True)] [Parameter(Mandatory=$True)]
[ValidateScript({Test-Path -Path $_ })] [ValidateScript({Test-Path -Path $_ })]

View File

@ -1,38 +1,12 @@
#!/snap/bin/powershell #!/snap/bin/powershell
Function Get-TimedScreenshot {
<# <#
.SYNOPSIS .SYNTAX ./take-screenshots.ps1
.DESCRIPTION takes multiple screenshots
Get-TimedScreenshot .LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
.DESCRIPTION
A function that takes screenshots and saves them to a folder.
.PARAMETER $Path
Specifies the folder path.
.PARAMETER $Interval
Specifies the interval in seconds between taking screenshots.
.PARAMETER $EndTime
Specifies when the script should stop running in the format HH-MM
.EXAMPLE
PS C:\> Get-TimedScreenshot -Path c:\temp\ -Interval 30 -EndTime 14:00
.LINK
http://obscuresecurity.blogspot.com/2013/01/Get-TimedScreenshot.html
https://github.com/obscuresec/random/blob/master/Get-TimedScreenshot
#> #>
Function Get-TimedScreenshot {
[CmdletBinding()] Param( [CmdletBinding()] Param(
[Parameter(Mandatory=$True)] [Parameter(Mandatory=$True)]
[ValidateScript({Test-Path -Path $_ })] [ValidateScript({Test-Path -Path $_ })]

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./test.ps1 .SYNTAX ./test.ps1
# Description: simple PowerShell test script .DESCRIPTION simple PowerShell test script
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
try { try {
write-output "✔️ PowerShell works. Details are:" write-output "✔️ PowerShell works. Details are:"

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./train-dns-cache.ps1 .SYNTAX ./train-dns-cache.ps1
# Description: trains the DNS cache with frequently used domain names .DESCRIPTION trains the DNS cache with frequently used domain names
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
Set-StrictMode -Version Latest Set-StrictMode -Version Latest

View File

@ -1,12 +1,13 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./translate-file.ps1 [<file>] .SYNTAX ./translate-file.ps1 [<file>] [<source-lang>] [<target-lang>]
# Description: translates the given file from source to target language. .DESCRIPTION translates the given file from source to target language.
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([string]$SourceFile, [string]$SourceLanguage, [string]$TargetLanguage) param([string]$SourceFile, [string]$SourceLanguage, [string]$TargetLanguage)
try { try {
if ($SourceFile -eq "" ) { if ($SourceFile -eq "" ) {
$SourceFile = read-host "Enter path to file" $SourceFile = read-host "Enter path to file"

View File

@ -1,16 +1,16 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./translate-text.ps1 [<text>] [<source-lang>]
.DESCRIPTION translates the given text into other languages
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./translate-text.ps1 [<text>] param([string]$SourceText, [string]$SourceLang = "en")
# Description: translates the given text into other languages
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
param([string]$SourceText)
if ($SourceText -eq "" ) { if ($SourceText -eq "" ) {
$SourceText = "Hello World!" $SourceText = read-host "Enter text to translate"
} }
$SourceLanguage = "en"
$TargetLanguages = "af","da","de","el","es","hr","it","ja","ko","pl","pt","nl","ru","tr","uk","vi" $TargetLanguages = "af","da","de","el","es","hr","it","ja","ko","pl","pt","nl","ru","tr","uk","vi"
function TranslateWithGoogle { function TranslateWithGoogle {
@ -36,7 +36,7 @@ function TranslateWithGoogle {
try { try {
foreach($TargetLanguage in $TargetLanguages) { foreach($TargetLanguage in $TargetLanguages) {
$Result = TranslateWithGoogle $SourceText $SourceLanguage $TargetLanguage $Result = TranslateWithGoogle $SourceText $SourceLang $TargetLanguage
write-output $TargetLanguage" : "$Result write-output $TargetLanguage" : "$Result
} }
exit 0 exit 0

View File

@ -1,16 +1,16 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./turn-volume-down.ps1 [<percent>]
.DESCRIPTION turns the audio volume down (-10% by default)
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./turn-volume-down.ps1 [<percent>] param([int]$Percent = 10)
# Description: turns the audio volume down (-10% by default)
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
Param([Int]$Percent = 10)
try { try {
$obj = New-Object -com wscript.shell $obj = New-Object -com wscript.shell
for ($i = 0; $i -lt $Percent; $i += 2) { for ([int]$i = 0; $i -lt $Percent; $i += 2) {
$obj.SendKeys([char]174) # each tick is -2% $obj.SendKeys([char]174) # each tick is -2%
} }
write-output "OK" write-output "OK"

View File

@ -1,16 +1,16 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./turn-volume-up.ps1 [<percent>]
.DESCRIPTION turns the audio volume up (+10% by default)
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./turn-volume-up.ps1 [<percent>] param([int]$Percent = 10)
# Description: turns the audio volume up (+10% by default)
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
Param([Int]$Percent = 10)
try { try {
$obj = New-Object -com wscript.shell $obj = New-Object -com wscript.shell
for ($i = 0; $i -lt $Percent; $i += 2) { for ([int]$i = 0; $i -lt $Percent; $i += 2) {
$obj.SendKeys([char]175) # each tick is +2% $obj.SendKeys([char]175) # each tick is +2%
} }
write-output "OK" write-output "OK"

View File

@ -1,17 +1,15 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./txt2wav.ps1
.DESCRIPTION converts the given text into an audio .WAV file
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./txt2wav.ps1
# Description: converts the given text into an audio .WAV file
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
# Configuration:
$Text = "Hello, my name ist Bond, James Bond" $Text = "Hello, my name ist Bond, James Bond"
$Speed = -1 # -10 is slowest, 10 is fastest $Speed = -1 # -10 is slowest, 10 is fastest
$TargetWavFile = "spoken.wav" $TargetWavFile = "spoken.wav"
# Run:
try { try {
Add-Type -AssemblyName System.Speech Add-Type -AssemblyName System.Speech
$SpeechSynthesizer = New-Object System.Speech.Synthesis.SpeechSynthesizer $SpeechSynthesizer = New-Object System.Speech.Synthesis.SpeechSynthesizer

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./unmute-audio.ps1 .SYNTAX ./unmute-audio.ps1
# Description: unmutes the audio .DESCRIPTION unmutes audio output
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
try { try {
$obj = new-object -com wscript.shell $obj = new-object -com wscript.shell

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./wakeup.ps1 [<hostname>] .SYNTAX ./wakeup.ps1 [<hostname>]
# Description: sends a magic packet to the given computer, waking him up .DESCRIPTION sends a magic packet to the given computer, waking him up
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([string]$Hostname) param([string]$Hostname)
if ($Hostname -eq "" ) { if ($Hostname -eq "" ) {

View File

@ -1,15 +1,14 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./weather-alert.ps1 .SYNTAX ./weather-alert.ps1
# Description: checks the current weather for critical values .DESCRIPTION checks the current weather for critical values
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
$GeoLocation="" # empty means determine automatically $GeoLocation="" # empty means determine automatically
function Check { function Check { param([int]$Value, [int]$NormalMin, [int]$NormalMax, [string]$Unit)
param ([int]$Value, [int]$NormalMin, [int]$NormalMax, [string]$Unit)
if ($Value -lt $NormalMin) { if ($Value -lt $NormalMin) {
return "$Value $Unit ! " return "$Value $Unit ! "
} }

View File

@ -1,15 +1,15 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./weather-report.ps1 [<geo-location>]
.DESCRIPTION prints the local weather report
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./weather-report.ps1 param([string]$GeoLocation = "") # empty means determine automatically
# Description: prints the local weather report
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
$GeoLocation="" # empty means determine automatically
try { try {
(Invoke-WebRequest http://v2d.wttr.in/$GeoLocation -UserAgent "curl" ).Content (invoke-webRequest http://v2d.wttr.in/$GeoLocation -UserAgent "curl" ).Content
exit 0 exit 0
} catch { } catch {
write-error "ERROR in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])" write-error "ERROR in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])"

View File

@ -1,10 +1,10 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./weather-worldwide.ps1 .SYNTAX ./weather-worldwide.ps1
# Description: prints the current weather of cities world-wide .DESCRIPTION prints the current weather of cities world-wide
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
$Cities="Hawaii","Los Angeles","Mexico City","Miami","New York","Rio de Janeiro","Paris","London","Berlin","Cape Town","Dubai","Mumbai","Singapore","Hong Kong","Peking","Tokyo","Sydney" $Cities="Hawaii","Los Angeles","Mexico City","Miami","New York","Rio de Janeiro","Paris","London","Berlin","Cape Town","Dubai","Mumbai","Singapore","Hong Kong","Peking","Tokyo","Sydney"

View File

@ -1,15 +1,15 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./weather.ps1 [<geo-location>]
.DESCRIPTION prints the current weather forecast
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./weather.ps1 param([string]$GeoLocation = "") # empty means determine automatically
# Description: prints the current weather forecast
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
$GeoLocation="" # empty means determine automatically
try { try {
(Invoke-WebRequest http://wttr.in/$GeoLocation -UserAgent "curl" ).Content (invoke-webRequest http://wttr.in/$GeoLocation -UserAgent "curl" ).Content
exit 0 exit 0
} catch { } catch {
write-error "ERROR in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])" write-error "ERROR in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])"

View File

@ -1,16 +1,16 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./write-big.ps1 [<text>]
.DESCRIPTION writes the given text in big letters
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./write-big.ps1 [<text>] param([string]$Text)
# Description: writes the given text in big letters
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
param([String]$Text)
Set-StrictMode -Version Latest Set-StrictMode -Version Latest
function BigA() { param([Int]$Row) function BigA() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " __ " } 1 { return " __ " }
2 { return " /__\ " } 2 { return " /__\ " }
@ -19,7 +19,7 @@ function BigA() { param([Int]$Row)
} }
} }
function BigB() { param([Int]$Row) function BigB() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " ____ " } 1 { return " ____ " }
2 { return "| _ )" } 2 { return "| _ )" }
@ -28,7 +28,7 @@ function BigB() { param([Int]$Row)
} }
} }
function BigC() { param([Int]$Row) function BigC() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " ___ " } 1 { return " ___ " }
2 { return " / __)" } 2 { return " / __)" }
@ -37,7 +37,7 @@ function BigC() { param([Int]$Row)
} }
} }
function BigD() { param([Int]$Row) function BigD() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " ____ " } 1 { return " ____ " }
2 { return "| _ \ " } 2 { return "| _ \ " }
@ -46,7 +46,7 @@ function BigD() { param([Int]$Row)
} }
} }
function BigE() { param([Int]$Row) function BigE() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " ____ " } 1 { return " ____ " }
2 { return "| ___)" } 2 { return "| ___)" }
@ -55,7 +55,7 @@ function BigE() { param([Int]$Row)
} }
} }
function BigF() { param([Int]$Row) function BigF() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " ____ " } 1 { return " ____ " }
2 { return "| ___)" } 2 { return "| ___)" }
@ -64,7 +64,7 @@ function BigF() { param([Int]$Row)
} }
} }
function BigG() { param([Int]$Row) function BigG() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " ____ " } 1 { return " ____ " }
2 { return " / ___)" } 2 { return " / ___)" }
@ -73,7 +73,7 @@ function BigG() { param([Int]$Row)
} }
} }
function BigH() { param([Int]$Row) function BigH() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " _ _ " } 1 { return " _ _ " }
2 { return "| |_| |" } 2 { return "| |_| |" }
@ -82,7 +82,7 @@ function BigH() { param([Int]$Row)
} }
} }
function BigI() { param([Int]$Row) function BigI() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " _ " } 1 { return " _ " }
2 { return "| |" } 2 { return "| |" }
@ -91,7 +91,7 @@ function BigI() { param([Int]$Row)
} }
} }
function BigJ() { param([Int]$Row) function BigJ() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " __ " } 1 { return " __ " }
2 { return " ( |" } 2 { return " ( |" }
@ -100,7 +100,7 @@ function BigJ() { param([Int]$Row)
} }
} }
function BigK() { param([Int]$Row) function BigK() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " _ _ " } 1 { return " _ _ " }
2 { return "| |/ )" } 2 { return "| |/ )" }
@ -109,7 +109,7 @@ function BigK() { param([Int]$Row)
} }
} }
function BigL() { param([Int]$Row) function BigL() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " _ " } 1 { return " _ " }
2 { return "| | " } 2 { return "| | " }
@ -118,7 +118,7 @@ function BigL() { param([Int]$Row)
} }
} }
function BigM() { param([Int]$Row) function BigM() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " _ _ " } 1 { return " _ _ " }
2 { return "| \ / |" } 2 { return "| \ / |" }
@ -127,7 +127,7 @@ function BigM() { param([Int]$Row)
} }
} }
function BigN() { param([Int]$Row) function BigN() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " _ _ " } 1 { return " _ _ " }
2 { return "| \ | |" } 2 { return "| \ | |" }
@ -136,7 +136,7 @@ function BigN() { param([Int]$Row)
} }
} }
function BigO() { param([Int]$Row) function BigO() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " ___ " } 1 { return " ___ " }
2 { return " / _ \ " } 2 { return " / _ \ " }
@ -145,7 +145,7 @@ function BigO() { param([Int]$Row)
} }
} }
function BigP() { param([Int]$Row) function BigP() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " ____ " } 1 { return " ____ " }
2 { return "| _ \" } 2 { return "| _ \" }
@ -154,7 +154,7 @@ function BigP() { param([Int]$Row)
} }
} }
function BigQ() { param([Int]$Row) function BigQ() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " ____ " } 1 { return " ____ " }
2 { return " / _ \ " } 2 { return " / _ \ " }
@ -163,7 +163,7 @@ function BigQ() { param([Int]$Row)
} }
} }
function BigR() { param([Int]$Row) function BigR() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " ____ " } 1 { return " ____ " }
2 { return "| _ \" } 2 { return "| _ \" }
@ -172,7 +172,7 @@ function BigR() { param([Int]$Row)
} }
} }
function BigS() { param([Int]$Row) function BigS() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " ____ " } 1 { return " ____ " }
2 { return "/ __)" } 2 { return "/ __)" }
@ -181,7 +181,7 @@ function BigS() { param([Int]$Row)
} }
} }
function BigT() { param([Int]$Row) function BigT() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " _____ " } 1 { return " _____ " }
2 { return "|_ _|" } 2 { return "|_ _|" }
@ -190,7 +190,7 @@ function BigT() { param([Int]$Row)
} }
} }
function BigU() { param([Int]$Row) function BigU() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " _ _ " } 1 { return " _ _ " }
2 { return "| | | |" } 2 { return "| | | |" }
@ -199,7 +199,7 @@ function BigU() { param([Int]$Row)
} }
} }
function BigV() { param([Int]$Row) function BigV() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " _ _ " } 1 { return " _ _ " }
2 { return "( \/ )" } 2 { return "( \/ )" }
@ -208,7 +208,7 @@ function BigV() { param([Int]$Row)
} }
} }
function BigW() { param([Int]$Row) function BigW() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " __ __ " } 1 { return " __ __ " }
2 { return "\ \/\/ /" } 2 { return "\ \/\/ /" }
@ -217,7 +217,7 @@ function BigW() { param([Int]$Row)
} }
} }
function BigX() { param([Int]$Row) function BigX() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " _ _ " } 1 { return " _ _ " }
2 { return "( \/ )" } 2 { return "( \/ )" }
@ -226,7 +226,7 @@ function BigX() { param([Int]$Row)
} }
} }
function BigY() { param([Int]$Row) function BigY() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " _ _ " } 1 { return " _ _ " }
2 { return "( \/ )" } 2 { return "( \/ )" }
@ -235,7 +235,7 @@ function BigY() { param([Int]$Row)
} }
} }
function BigZ() { param([Int]$Row) function BigZ() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " ____ " } 1 { return " ____ " }
2 { return "(_ )" } 2 { return "(_ )" }
@ -245,7 +245,7 @@ function BigZ() { param([Int]$Row)
} }
function Big0() { param([Int]$Row) function Big0() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " ___ " } 1 { return " ___ " }
2 { return " / _ \ " } 2 { return " / _ \ " }
@ -254,7 +254,7 @@ function Big0() { param([Int]$Row)
} }
} }
function Big1() { param([Int]$Row) function Big1() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " ___ " } 1 { return " ___ " }
2 { return "/_ |" } 2 { return "/_ |" }
@ -263,7 +263,7 @@ function Big1() { param([Int]$Row)
} }
} }
function Big2() { param([Int]$Row) function Big2() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " ___ " } 1 { return " ___ " }
2 { return "(__ \ " } 2 { return "(__ \ " }
@ -272,7 +272,7 @@ function Big2() { param([Int]$Row)
} }
} }
function Big3() { param([Int]$Row) function Big3() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " ___ " } 1 { return " ___ " }
2 { return "(__ )" } 2 { return "(__ )" }
@ -281,7 +281,7 @@ function Big3() { param([Int]$Row)
} }
} }
function Big4() { param([Int]$Row) function Big4() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " __ " } 1 { return " __ " }
2 { return " /. | " } 2 { return " /. | " }
@ -290,7 +290,7 @@ function Big4() { param([Int]$Row)
} }
} }
function Big5() { param([Int]$Row) function Big5() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " ____ " } 1 { return " ____ " }
2 { return "| ___)" } 2 { return "| ___)" }
@ -299,7 +299,7 @@ function Big5() { param([Int]$Row)
} }
} }
function Big6() { param([Int]$Row) function Big6() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " _ " } 1 { return " _ " }
2 { return " / ) " } 2 { return " / ) " }
@ -308,7 +308,7 @@ function Big6() { param([Int]$Row)
} }
} }
function Big7() { param([Int]$Row) function Big7() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " ___ " } 1 { return " ___ " }
2 { return "(__ )" } 2 { return "(__ )" }
@ -317,7 +317,7 @@ function Big7() { param([Int]$Row)
} }
} }
function Big8() { param([Int]$Row) function Big8() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " ___ " } 1 { return " ___ " }
2 { return "( _ )" } 2 { return "( _ )" }
@ -326,7 +326,7 @@ function Big8() { param([Int]$Row)
} }
} }
function Big9() { param([Int]$Row) function Big9() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " ___ " } 1 { return " ___ " }
2 { return "/ _ \" } 2 { return "/ _ \" }
@ -335,7 +335,7 @@ function Big9() { param([Int]$Row)
} }
} }
function BigColon() { param([Int]$Row) function BigColon() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " " } 1 { return " " }
2 { return " o " } 2 { return " o " }
@ -344,7 +344,7 @@ function BigColon() { param([Int]$Row)
} }
} }
function BigMinus() { param([Int]$Row) function BigMinus() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return " " } 1 { return " " }
2 { return " ____ " } 2 { return " ____ " }
@ -353,7 +353,7 @@ function BigMinus() { param([Int]$Row)
} }
} }
function BigChar() { param([String]$Char, [Int]$Row) function BigChar() { param([string]$Char, [int]$Row)
switch($Char) { switch($Char) {
'A' { return BigA $Row } 'A' { return BigA $Row }
'B' { return BigB $Row } 'B' { return BigB $Row }

View File

@ -1,17 +1,18 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./write-blue.ps1 [<text>]
.DESCRIPTION writes the given text in a blue foreground color
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./write-blue.ps1 [<text>] param([string]$Text)
# Description: writes the given text in a blue foreground color
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
param([String]$Text)
try { try {
if ($Text -eq "" ) { if ($Text -eq "" ) {
[String]$Text = read-host "Enter text to write" [String]$Text = read-host "Enter text to write"
} }
write-host -foregroundcolor blue $Text write-host -foregroundColor blue $Text
exit 0 exit 0
} catch { } catch {
write-error "ERROR in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])" write-error "ERROR in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])"

View File

@ -1,14 +1,14 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX write-braille.ps1 [<text>]
.DESCRIPTION writes the given text in Braille
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./write-braille.ps1 [<text>] param([string]$Text)
# Description: writes the given text in Braille
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
param([String]$Text) function BrailleA() { param([int]$Row)
function BrailleA() { param([Int]$Row)
switch($Row) { switch($Row) {
1 { return ".o" } 1 { return ".o" }
2 { return "oo" } 2 { return "oo" }
@ -16,7 +16,7 @@ function BrailleA() { param([Int]$Row)
} }
} }
function BrailleB() { param([Int]$Row) function BrailleB() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".o" } 1 { return ".o" }
2 { return ".o" } 2 { return ".o" }
@ -24,7 +24,7 @@ function BrailleB() { param([Int]$Row)
} }
} }
function BrailleC() { param([Int]$Row) function BrailleC() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".." } 1 { return ".." }
2 { return "oo" } 2 { return "oo" }
@ -32,7 +32,7 @@ function BrailleC() { param([Int]$Row)
} }
} }
function BrailleD() { param([Int]$Row) function BrailleD() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".." } 1 { return ".." }
2 { return "o." } 2 { return "o." }
@ -40,7 +40,7 @@ function BrailleD() { param([Int]$Row)
} }
} }
function BrailleE() { param([Int]$Row) function BrailleE() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".o" } 1 { return ".o" }
2 { return "o." } 2 { return "o." }
@ -48,7 +48,7 @@ function BrailleE() { param([Int]$Row)
} }
} }
function BrailleF() { param([Int]$Row) function BrailleF() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".." } 1 { return ".." }
2 { return ".o" } 2 { return ".o" }
@ -56,7 +56,7 @@ function BrailleF() { param([Int]$Row)
} }
} }
function BrailleG() { param([Int]$Row) function BrailleG() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".." } 1 { return ".." }
2 { return ".." } 2 { return ".." }
@ -64,7 +64,7 @@ function BrailleG() { param([Int]$Row)
} }
} }
function BrailleH() { param([Int]$Row) function BrailleH() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".o" } 1 { return ".o" }
2 { return ".." } 2 { return ".." }
@ -72,7 +72,7 @@ function BrailleH() { param([Int]$Row)
} }
} }
function BrailleI() { param([Int]$Row) function BrailleI() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return "o." } 1 { return "o." }
2 { return ".o" } 2 { return ".o" }
@ -80,7 +80,7 @@ function BrailleI() { param([Int]$Row)
} }
} }
function BrailleJ() { param([Int]$Row) function BrailleJ() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return "o." } 1 { return "o." }
2 { return ".." } 2 { return ".." }
@ -88,7 +88,7 @@ function BrailleJ() { param([Int]$Row)
} }
} }
function BrailleK() { param([Int]$Row) function BrailleK() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".o" } 1 { return ".o" }
2 { return "oo" } 2 { return "oo" }
@ -96,7 +96,7 @@ function BrailleK() { param([Int]$Row)
} }
} }
function BrailleL() { param([Int]$Row) function BrailleL() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".o" } 1 { return ".o" }
2 { return ".o" } 2 { return ".o" }
@ -104,7 +104,7 @@ function BrailleL() { param([Int]$Row)
} }
} }
function BrailleM() { param([Int]$Row) function BrailleM() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".." } 1 { return ".." }
2 { return "oo" } 2 { return "oo" }
@ -112,7 +112,7 @@ function BrailleM() { param([Int]$Row)
} }
} }
function BrailleN() { param([Int]$Row) function BrailleN() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".." } 1 { return ".." }
2 { return "o." } 2 { return "o." }
@ -120,7 +120,7 @@ function BrailleN() { param([Int]$Row)
} }
} }
function BrailleO() { param([Int]$Row) function BrailleO() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".o" } 1 { return ".o" }
2 { return "o." } 2 { return "o." }
@ -128,7 +128,7 @@ function BrailleO() { param([Int]$Row)
} }
} }
function BrailleP() { param([Int]$Row) function BrailleP() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".." } 1 { return ".." }
2 { return ".o" } 2 { return ".o" }
@ -136,7 +136,7 @@ function BrailleP() { param([Int]$Row)
} }
} }
function BrailleQ() { param([Int]$Row) function BrailleQ() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".." } 1 { return ".." }
2 { return ".." } 2 { return ".." }
@ -144,7 +144,7 @@ function BrailleQ() { param([Int]$Row)
} }
} }
function BrailleR() { param([Int]$Row) function BrailleR() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".o" } 1 { return ".o" }
2 { return ".." } 2 { return ".." }
@ -152,7 +152,7 @@ function BrailleR() { param([Int]$Row)
} }
} }
function BrailleS() { param([Int]$Row) function BrailleS() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return "o." } 1 { return "o." }
2 { return ".o" } 2 { return ".o" }
@ -160,7 +160,7 @@ function BrailleS() { param([Int]$Row)
} }
} }
function BrailleT() { param([Int]$Row) function BrailleT() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return "o." } 1 { return "o." }
2 { return ".." } 2 { return ".." }
@ -168,7 +168,7 @@ function BrailleT() { param([Int]$Row)
} }
} }
function BrailleU() { param([Int]$Row) function BrailleU() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".o" } 1 { return ".o" }
2 { return "oo" } 2 { return "oo" }
@ -176,7 +176,7 @@ function BrailleU() { param([Int]$Row)
} }
} }
function BrailleV() { param([Int]$Row) function BrailleV() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".o" } 1 { return ".o" }
2 { return ".o" } 2 { return ".o" }
@ -184,7 +184,7 @@ function BrailleV() { param([Int]$Row)
} }
} }
function BrailleW() { param([Int]$Row) function BrailleW() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return "o." } 1 { return "o." }
2 { return ".." } 2 { return ".." }
@ -192,7 +192,7 @@ function BrailleW() { param([Int]$Row)
} }
} }
function BrailleX() { param([Int]$Row) function BrailleX() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".." } 1 { return ".." }
2 { return "oo" } 2 { return "oo" }
@ -200,7 +200,7 @@ function BrailleX() { param([Int]$Row)
} }
} }
function BrailleY() { param([Int]$Row) function BrailleY() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".." } 1 { return ".." }
2 { return "o." } 2 { return "o." }
@ -208,7 +208,7 @@ function BrailleY() { param([Int]$Row)
} }
} }
function BrailleZ() { param([Int]$Row) function BrailleZ() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".o" } 1 { return ".o" }
2 { return "o." } 2 { return "o." }
@ -216,7 +216,7 @@ function BrailleZ() { param([Int]$Row)
} }
} }
function Braille1() { param([Int]$Row) function Braille1() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".o" } 1 { return ".o" }
2 { return "oo" } 2 { return "oo" }
@ -224,7 +224,7 @@ function Braille1() { param([Int]$Row)
} }
} }
function Braille2() { param([Int]$Row) function Braille2() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".o" } 1 { return ".o" }
2 { return ".o" } 2 { return ".o" }
@ -232,7 +232,7 @@ function Braille2() { param([Int]$Row)
} }
} }
function Braille3() { param([Int]$Row) function Braille3() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".." } 1 { return ".." }
2 { return "oo" } 2 { return "oo" }
@ -240,7 +240,7 @@ function Braille3() { param([Int]$Row)
} }
} }
function Braille4() { param([Int]$Row) function Braille4() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".." } 1 { return ".." }
2 { return "o." } 2 { return "o." }
@ -248,7 +248,7 @@ function Braille4() { param([Int]$Row)
} }
} }
function Braille5() { param([Int]$Row) function Braille5() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".o" } 1 { return ".o" }
2 { return "o." } 2 { return "o." }
@ -256,7 +256,7 @@ function Braille5() { param([Int]$Row)
} }
} }
function Braille6() { param([Int]$Row) function Braille6() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".." } 1 { return ".." }
2 { return ".o" } 2 { return ".o" }
@ -264,7 +264,7 @@ function Braille6() { param([Int]$Row)
} }
} }
function Braille7() { param([Int]$Row) function Braille7() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".." } 1 { return ".." }
2 { return ".." } 2 { return ".." }
@ -272,7 +272,7 @@ function Braille7() { param([Int]$Row)
} }
} }
function Braille8() { param([Int]$Row) function Braille8() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return ".o" } 1 { return ".o" }
2 { return ".." } 2 { return ".." }
@ -280,7 +280,7 @@ function Braille8() { param([Int]$Row)
} }
} }
function Braille9() { param([Int]$Row) function Braille9() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return "o." } 1 { return "o." }
2 { return ".o" } 2 { return ".o" }
@ -288,7 +288,7 @@ function Braille9() { param([Int]$Row)
} }
} }
function Braille0() { param([Int]$Row) function Braille0() { param([int]$Row)
switch($Row) { switch($Row) {
1 { return "o." } 1 { return "o." }
2 { return ".." } 2 { return ".." }
@ -296,7 +296,7 @@ function Braille0() { param([Int]$Row)
} }
} }
function BrailleChar() { param([String]$Char, [Int]$Row) function BrailleChar() { param([string]$Char, [int]$Row)
switch($Char) { switch($Char) {
'A' { return BrailleA $Row } 'A' { return BrailleA $Row }
'B' { return BrailleB $Row } 'B' { return BrailleB $Row }

View File

@ -1,17 +1,18 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./write-green.ps1 [<text>]
.DESCRIPTION writes the given text in a green foreground color
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./write-green.ps1 [<text>] param([string]$Text = "")
# Description: writes the given text in a green foreground color
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
param([String]$Text)
try { try {
if ($Text -eq "" ) { if ($Text -eq "" ) {
[String]$Text = read-host "Enter text to write" [string]$Text = read-host "Enter text to write"
} }
write-host -foregroundcolor green $Text write-host -foregroundColor green $Text
exit 0 exit 0
} catch { } catch {
write-error "ERROR in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])" write-error "ERROR in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])"

View File

@ -1,17 +1,18 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./write-logbook.ps1 [<text>]
.DESCRIPTION writes the given text to the logbook (../Data/Logbook.csv)
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./write-logbook.ps1 [<text>] param([string]$Text = "")
# Description: writes the given text to the logbook (../Data/Logbook.csv)
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
param([String]$Text)
try { try {
$Time = Get-Date -format "yyyy-MM-ddTHH:mm:ssZ" -AsUTC $Time = get-date -format "yyyy-MM-ddTHH:mm:ssZ" -asUTC
$User = $(whoami) $User = $(whoami)
if ($Text -eq "" ) { if ($Text -eq "" ) {
[String]$Text = read-host "Enter text to write" [string]$Text = read-host "Enter text to write"
} }
$Line = "$Time,$User,$Text" $Line = "$Time,$User,$Text"

View File

@ -1,16 +1,15 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./write-morse-code.ps1 [<text>] [<speed>]
.DESCRIPTION writes the given text in Morse code
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./write-morse-code.ps1 [<text>] param([string]$Text, [int]$OneTimeUnit = 100) # in milliseconds
# Description: writes the given text in Morse code
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
param([String]$Text) function gap() { param([int]$Length)
$OneTimeUnit = 100 # milliseconds for ([int]$i = 1; $i -lt $Length; $i++) {
function gap() { param([Int]$Length)
for ($i = 1; $i -lt $Length; $i++) {
write-host " " -nonewline write-host " " -nonewline
} }
start-sleep -milliseconds ($Length * $OneTimeUnit) start-sleep -milliseconds ($Length * $OneTimeUnit)
@ -26,7 +25,7 @@ function dash() {
start-sleep -milliseconds (3 * $OneTimeUnit) # signal start-sleep -milliseconds (3 * $OneTimeUnit) # signal
} }
function Char2MorseCode() { param([String]$Char) function Char2MorseCode() { param([string]$Char)
switch($Char) { switch($Char) {
'A' { dot; gap 1; dash; gap 3 } 'A' { dot; gap 1; dash; gap 3 }
'B' { dash; gap 1; dot; gap 1; dot; gap 1; dot; gap 3 } 'B' { dash; gap 1; dot; gap 1; dot; gap 1; dot; gap 3 }
@ -70,7 +69,7 @@ function Char2MorseCode() { param([String]$Char)
try { try {
if ($Text -eq "" ) { if ($Text -eq "" ) {
[String]$Text = read-host "Enter text to write" [string]$Text = read-host "Enter text to write"
} }
[char[]]$ArrayOfChars = $Text.ToUpper() [char[]]$ArrayOfChars = $Text.ToUpper()
foreach($Char in $ArrayOfChars) { foreach($Char in $ArrayOfChars) {

View File

@ -1,14 +1,12 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./write-motd.ps1 .SYNTAX ./write-motd.ps1
# Description: writes the message of the day (MOTD) .DESCRIPTION writes the message of the day (MOTD)
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
# Retrieve information: # Retrieve information:
$CurrentTime = Get-Date -format "yyyy-MM-dd HH:mm" $CurrentTime = Get-Date -format "yyyy-MM-dd HH:mm"
$TimeZone = (Get-TimeZone).id $TimeZone = (Get-TimeZone).id
$UserName = $(whoami) $UserName = $(whoami)

View File

@ -1,15 +1,16 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./write-red.ps1 [<text>]
.DESCRIPTION writes the given text in a red foreground color
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./write-red.ps1 [<text>] param([string]$Text = "")
# Description: writes the given text in a red foreground color
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
param([String]$Text)
try { try {
if ($Text -eq "" ) { if ($Text -eq "" ) {
[String]$Text = read-host "Enter text to write" [string]$Text = read-host "Enter text to write"
} }
write-host -foregroundcolor red $Text write-host -foregroundcolor red $Text
exit 0 exit 0

View File

@ -1,14 +1,14 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./write-rot13.ps1 [<text>]
.DESCRIPTION encodes or decodes the given text with ROT13
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./write-rot13.ps1 [<text>] param([string]$Text)
# Description: encodes or decodes the given text with ROT13
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
param([String]$Text) function ROT13 { param([string]$Text)
function ROT13 { param([String]$Text)
$Text.ToCharArray() | ForEach-Object { $Text.ToCharArray() | ForEach-Object {
if ((([int] $_ -ge 97) -and ([int] $_ -le 109)) -or (([int] $_ -ge 65) -and ([int] $_ -le 77))) { if ((([int] $_ -ge 97) -and ([int] $_ -le 109)) -or (([int] $_ -ge 65) -and ([int] $_ -le 77))) {
$Result += [char] ([int] $_ + 13); $Result += [char] ([int] $_ + 13);
@ -23,7 +23,7 @@ function ROT13 { param([String]$Text)
try { try {
if ($Text -eq "" ) { if ($Text -eq "" ) {
[String]$Text = read-host "Enter text to write" [string]$Text = read-host "Enter text to write"
} }
$Result = ROT13 $Text $Result = ROT13 $Text
write-output $Result write-output $Result

View File

@ -1,23 +1,23 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./write-typewriter.ps1 [<text>] [<speed>]
.DESCRIPTION writes the given text with the typewriter effect
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./write-typewriter.ps1 [<text>] param([string]$Text = "", [int]$Speed = 250) # in milliseconds
# Description: writes the given test with the typewriter effect
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
param([string]$Text)
if ($Text -eq "" ) { if ($Text -eq "" ) {
$Text = "`nHello World`n-----------`nPowerShell is cross-platform`nPowerShell is open-source`nPowerShell is easy to learn`nPowerShell is fully documented`n`nThanks for watching`n`n:-)`n`n" $Text = "`nHello World`n-----------`nPowerShell is cross-platform`nPowerShell is open-source`nPowerShell is easy to learn`nPowerShell is fully documented`n`nThanks for watching`n`n:-)`n`n"
} }
$Speed = 250 # milliseconds
try { try {
$Random = New-Object System.Random $Random = New-Object System.Random
$Text -split '' | ForEach-Object { $Text -split '' | ForEach-Object {
Write-Host -nonewline $_ write-host -nonewline $_
Start-Sleep -milliseconds $(1 + $Random.Next($Speed)) start-sleep -milliseconds $(1 + $Random.Next($Speed))
} }
exit 0 exit 0
} catch { } catch {

View File

@ -1,15 +1,16 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./write-uppercase.ps1 [<text>]
.DESCRIPTION writes the given text in uppercase letters
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./write-uppercase.ps1 [<text>] param([string]$Text = "")
# Description: writes the given text in uppercase letters
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
param([String]$Text)
try { try {
if ($Text -eq "" ) { if ($Text -eq "" ) {
[String]$Text = read-host "Enter text to write" [string]$Text = read-host "Enter text to write"
} }
write-output $Text.ToUpper() write-output $Text.ToUpper()
exit 0 exit 0

View File

@ -1,12 +1,13 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
.SYNTAX ./write-vertical.ps1 [<text>]
.DESCRIPTION writes the given text in vertical direction
.LINK https://github.com/fleschutz/PowerShell
.NOTES Author: Markus Fleschutz / License: CC0
#>
# Syntax: ./write-vertical.ps1 [<text>] param([string]$Text = "")
# Description: writes the given text in vertical direction
# Author: Markus Fleschutz
# Source: github.com/fleschutz/PowerShell
# License: CC0
param([String]$Text)
try { try {
if ($Text -eq "" ) { if ($Text -eq "" ) {
[String]$Text = read-host "Enter text to write" [String]$Text = read-host "Enter text to write"

View File

@ -1,18 +1,20 @@
#!/snap/bin/powershell #!/snap/bin/powershell
<#
# Syntax: ./zip-dir.ps1 [<path-to-folder>] .SYNTAX ./zip-dir.ps1 [<path-to-folder>]
# Description: creates a zip archive of the given folder .DESCRIPTION creates a zip archive of the given folder
# Author: Markus Fleschutz .LINK https://github.com/fleschutz/PowerShell
# Source: github.com/fleschutz/PowerShell .NOTES Author: Markus Fleschutz / License: CC0
# License: CC0 #>
param([string]$Path) param([string]$Path)
try { try {
if ($Path -eq "" ) { if ($Path -eq "" ) {
$URL = read-host "Enter path to folder to zip" $URL = read-host "Enter path to folder"
} }
Compress-Archive -Path $Path -DestinationPath $Path.zip compress-archive -path $Path -destinationPath $Path.zip
write-output "OK - folder has been compressed to $($Path).zip"
exit 0 exit 0
} catch { } catch {
write-error "ERROR in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])" write-error "ERROR in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])"