PowerShell/docs/watch-news.md

114 lines
3.1 KiB
Markdown
Raw Normal View History

2024-05-19 10:25:56 +02:00
Script: *watch-news.ps1*
========================
This PowerShell script lists the latest headlines by using a RSS (Really Simple Syndication) feed.
Parameters
----------
```powershell
2024-08-15 09:51:46 +02:00
PS> ./watch-news.ps1 [[-RSS_URL] <String>] [[-lines] <Int32>] [[-timeInterval] <Int32>] [<CommonParameters>]
2024-05-19 10:25:56 +02:00
-RSS_URL <String>
Specifies the URL to the RSS feed (Yahoo World News by default)
Required? false
Position? 1
Default value https://news.yahoo.com/rss/world
Accept pipeline input? false
Accept wildcard characters? false
2024-08-15 09:51:46 +02:00
-lines <Int32>
Specifies the initial number of headlines
2024-05-19 10:25:56 +02:00
Required? false
Position? 2
2024-08-15 09:51:46 +02:00
Default value 10
Accept pipeline input? false
Accept wildcard characters? false
-timeInterval <Int32>
Specifies the time interval in seconds between the Web requests
Required? false
Position? 3
Default value 30
2024-05-19 10:25:56 +02:00
Accept pipeline input? false
Accept wildcard characters? false
[<CommonParameters>]
This script supports the common parameters: Verbose, Debug, ErrorAction, ErrorVariable, WarningAction,
WarningVariable, OutBuffer, PipelineVariable, and OutVariable.
```
Example
-------
```powershell
2024-08-15 09:51:46 +02:00
PS> ./watch-news.ps1
❇️ Niger coup: Ecowas deadline sparks anxiety in northern Nigeria ❇️
2024-05-19 10:25:56 +02:00
```
Notes
-----
Author: Markus Fleschutz | License: CC0
Related Links
-------------
https://github.com/fleschutz/PowerShell
Script Content
--------------
```powershell
<#
.SYNOPSIS
Watch the latest headlines
.DESCRIPTION
This PowerShell script lists the latest headlines by using a RSS (Really Simple Syndication) feed.
.PARAMETER RSS_URL
Specifies the URL to the RSS feed (Yahoo World News by default)
2024-08-15 09:51:46 +02:00
.PARAMETER lines
Specifies the initial number of headlines
.PARAMETER timeInterval
Specifies the time interval in seconds between the Web requests
2024-05-19 10:25:56 +02:00
.EXAMPLE
2024-08-15 09:51:46 +02:00
PS> ./watch-news.ps1
❇️ Niger coup: Ecowas deadline sparks anxiety in northern Nigeria ❇️
2024-05-19 10:25:56 +02:00
.LINK
https://github.com/fleschutz/PowerShell
.NOTES
Author: Markus Fleschutz | License: CC0
#>
2024-08-15 09:51:46 +02:00
param([string]$RSS_URL = "https://news.yahoo.com/rss/world", [int]$lines = 10, [int]$timeInterval = 30) # in seconds
2024-05-19 10:25:56 +02:00
2024-08-15 09:51:46 +02:00
function PrintLatestHeadlines([string]$previous, [int]$maxLines) {
2024-05-19 10:25:56 +02:00
[xml]$content = (Invoke-WebRequest -URI $RSS_URL -useBasicParsing).Content
2024-08-15 09:51:46 +02:00
[string]$latest = ""
foreach ($item in $content.rss.channel.item) {
$itemTitle = "$($item.title)"
if ($latest -eq "") { $latest = $itemTitle }
if ($itemTitle -eq $previous) { break }
& "$PSScriptRoot/write-animated.ps1" "❇️ $itemTitle ❇️"
$maxLines--
if ($maxLines -eq 0) { break }
}
return $latest
2024-05-19 10:25:56 +02:00
}
try {
2024-08-15 09:51:46 +02:00
$latest = ""
2024-05-19 10:25:56 +02:00
while ($true) {
2024-08-15 09:51:46 +02:00
$latest = PrintLatestHeadlines $latest $lines
Start-Sleep -seconds $timeInterval
2024-05-19 10:25:56 +02:00
}
exit 0 # success
} catch {
"⚠️ Error in line $($_.InvocationInfo.ScriptLineNumber): $($Error[0])"
exit 1
}
```
2024-08-15 09:51:46 +02:00
*(generated by convert-ps2md.ps1 using the comment-based help of watch-news.ps1 as of 08/15/2024 09:50:55)*