mirror of
https://github.com/isjerryxiao/pacroller.git
synced 2024-11-22 07:40:43 +08:00
news feed test
This commit is contained in:
parent
b4dceac194
commit
0c41cb7aa2
1 changed files with 35 additions and 0 deletions
35
src/pacroller/arch-news-feed.py
Normal file
35
src/pacroller/arch-news-feed.py
Normal file
|
@ -0,0 +1,35 @@
|
||||||
|
import urllib.request
|
||||||
|
from xml.etree import ElementTree as etree
|
||||||
|
from typing import List
|
||||||
|
|
||||||
|
def get_news(old_news: str) -> List[str]:
|
||||||
|
ARCH_RSS_URL = 'https://archlinux.org/feeds/news/'
|
||||||
|
headers = {'User-Agent': 'Mozilla/5.0 (compatible; Pacroller/0.1; +https://github.com/isjerryxiao/pacroller)'}
|
||||||
|
req = urllib.request.Request(ARCH_RSS_URL, data=None, headers=headers)
|
||||||
|
rss_text = urllib.request.urlopen(req).read().decode('utf-8')
|
||||||
|
|
||||||
|
xml_root = etree.fromstring(rss_text)
|
||||||
|
elements: List[etree.Element] = xml_root.findall('channel/item')
|
||||||
|
|
||||||
|
news: List[str] = list()
|
||||||
|
for elem in elements:
|
||||||
|
title = elem.findtext('title') or 'No title'
|
||||||
|
link = elem.findtext('link') or ''
|
||||||
|
date = elem.findtext('pubDate') or 'No date'
|
||||||
|
news.append(f"{date} | {title} ({link})".rstrip())
|
||||||
|
return news[:news.index(old_news)] if old_news in news else news
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
from pathlib import Path
|
||||||
|
f = Path('/tmp/pacroller-news.db')
|
||||||
|
if f.exists():
|
||||||
|
old_news = f.read_text()
|
||||||
|
else:
|
||||||
|
old_news = None
|
||||||
|
news = get_news(old_news)
|
||||||
|
if news:
|
||||||
|
f.write_text(news[0])
|
||||||
|
for i in news:
|
||||||
|
print(i)
|
||||||
|
else:
|
||||||
|
print(f'nothing new, {old_news=}')
|
Loading…
Reference in a new issue