blob: 72e3bad022924c4032383602ecb8c606aadf8ef7 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
#!/usr/bin/python3
from feedgen.feed import FeedGenerator
import os
import re
import operator
from datetime import datetime
leader='https://kenkellner.com/blog/'
links = os.listdir('build')
links.remove('index.html')
if 'feed.xml' in links:
links.remove('feed.xml')
src = []
for i in links:
src.append('src/'+i.replace('.html','.Rmd'))
dates = []
for i in src:
for line in open(i):
if 'date: ' in line:
dates.append(line.split(': ')[1].strip('\n'))
break
titles = []
for i in src:
for line in open(i):
if 'title: ' in line:
title_raw = line.split(': ',1)[1].strip('\n')
title_raw = re.sub(r"^'","",title_raw)
title_raw = re.sub(r"'$","",title_raw)
titles.append(title_raw)
break
dates, links, titles = zip(*sorted(zip(dates, links, titles)))
fg = FeedGenerator()
fg.id(leader)
fg.link(href=leader+'feed.xml', rel='self')
fg.title('Ken Kellner\'s Blog')
fg.subtitle(' ')
fg.language('en')
for i in range(len(dates)):
fe = fg.add_entry()
fe.title(titles[i])
fe.id(leader+links[i])
fe.link(href=leader+links[i])
fe.author({'name': 'Ken Kellner', 'email': 'contact@kenkellner.com'})
fe.description('')
date_raw = dates[i]+' -0500'
fe.published(datetime.strptime(date_raw, '%Y-%m-%d %z'))
fg.rss_str(pretty=True)
fg.rss_file('build/feed.xml')
|