cover fix
This commit is contained in:
parent
e0ed5e50c5
commit
cf62814378
4 changed files with 158 additions and 502 deletions
2
.gitignore
vendored
2
.gitignore
vendored
|
@ -3,4 +3,4 @@ media/
|
||||||
pdf/
|
pdf/
|
||||||
|
|
||||||
*.json
|
*.json
|
||||||
*.pdf
|
|
||||||
|
|
BIN
copertina.pdf
Normal file
BIN
copertina.pdf
Normal file
Binary file not shown.
344
copertina.svg
344
copertina.svg
File diff suppressed because one or more lines are too long
Before Width: | Height: | Size: 42 KiB |
310
oloturia2pdf.py
310
oloturia2pdf.py
|
@ -21,28 +21,26 @@ def copertina(text):
|
||||||
from PyPDF2 import PdfFileWriter, PdfFileReader
|
from PyPDF2 import PdfFileWriter, PdfFileReader
|
||||||
import io
|
import io
|
||||||
from reportlab.pdfgen import canvas
|
from reportlab.pdfgen import canvas
|
||||||
from reportlab.lib.pagesizes import A4
|
from reportlab.lib.pagesizes import A5
|
||||||
from reportlab.pdfbase import pdfmetrics
|
from reportlab.pdfbase import pdfmetrics
|
||||||
from reportlab.pdfbase.ttfonts import TTFont
|
from reportlab.pdfbase.ttfonts import TTFont
|
||||||
from reportlab.pdfbase.pdfmetrics import stringWidth
|
from reportlab.pdfbase.pdfmetrics import stringWidth
|
||||||
from reportlab.rl_config import defaultPageSize
|
|
||||||
|
|
||||||
FONT = 'Roboto'
|
FONT = 'Roboto'
|
||||||
SIZE = 48
|
SIZE = 36
|
||||||
|
|
||||||
packet = io.BytesIO()
|
packet = io.BytesIO()
|
||||||
# create a new PDF with Reportlab
|
# create a new PDF with Reportlab
|
||||||
|
|
||||||
pdfmetrics.registerFont(TTFont("Roboto", "template/roboto-regular-webfont.ttf"))
|
pdfmetrics.registerFont(TTFont("Roboto", "template/roboto-regular-webfont.ttf"))
|
||||||
|
|
||||||
can = canvas.Canvas(packet, pagesize=A4)
|
can = canvas.Canvas(packet, pagesize=A5)
|
||||||
can.setFont(FONT, SIZE)
|
can.setFont(FONT, SIZE)
|
||||||
|
|
||||||
PAGE_WIDTH = defaultPageSize[0]
|
PAGE_WIDTH = A5[0]
|
||||||
#PAGE_HEIGHT = defaultPageSize[1]
|
|
||||||
|
|
||||||
text_width = stringWidth(text,FONT, SIZE)
|
text_width = stringWidth(text,FONT, SIZE)
|
||||||
can.drawString((PAGE_WIDTH - text_width) / 2, 150, text)
|
can.drawString((PAGE_WIDTH - text_width) / 2, 100, text)
|
||||||
can.save()
|
can.save()
|
||||||
|
|
||||||
#move to the beginning of the StringIO buffer
|
#move to the beginning of the StringIO buffer
|
||||||
|
@ -60,178 +58,180 @@ def copertina(text):
|
||||||
return(page)
|
return(page)
|
||||||
|
|
||||||
|
|
||||||
|
def main():
|
||||||
|
# Scarica tutti i post da Mastodon
|
||||||
|
|
||||||
# Scarica tutti i post da Mastodon
|
print("Scarico i post")
|
||||||
|
|
||||||
print("Scarico i post")
|
def default(o):
|
||||||
|
if isinstance(o, (datetime.date, datetime.datetime)):
|
||||||
|
return o.isoformat()
|
||||||
|
|
||||||
def default(o):
|
if not os.path.isfile('oloturiadump.json'):
|
||||||
if isinstance(o, (datetime.date, datetime.datetime)):
|
mastodon = Mastodon(api_base_url = "https://mastodon.bida.im")
|
||||||
return o.isoformat()
|
all_vgos = []
|
||||||
|
last_id = None
|
||||||
|
|
||||||
if not os.path.isfile('oloturiadump.json'):
|
while True:
|
||||||
mastodon = Mastodon(api_base_url = "https://mastodon.bida.im")
|
statuses = list(filter(lambda s: s['account']['username'] == 'oloturia', mastodon.timeline_hashtag("vgo", local=True, max_id=last_id)))
|
||||||
all_vgos = []
|
if not statuses:
|
||||||
last_id = None
|
break
|
||||||
|
all_vgos += list(map(
|
||||||
|
lambda s: {
|
||||||
|
'id': s['id'],
|
||||||
|
'uri': s['uri'],
|
||||||
|
'content': s['content'],
|
||||||
|
'replies_count': s['replies_count'],
|
||||||
|
#'replies': mastodon.status_context(s['id']) if s['replies_count'] > 0 else [],
|
||||||
|
'created': s['created_at'],
|
||||||
|
'reblogs': s['reblogs_count'],
|
||||||
|
'favourites': s['favourites_count'],
|
||||||
|
'media': s['media_attachments']
|
||||||
|
}
|
||||||
|
, statuses))
|
||||||
|
last_id = statuses[-1]['id']
|
||||||
|
|
||||||
while True:
|
#print(all_vgos)
|
||||||
statuses = list(filter(lambda s: s['account']['username'] == 'oloturia', mastodon.timeline_hashtag("vgo", local=True, max_id=last_id)))
|
#print(json.dumps(all_vgos, default=default))
|
||||||
if not statuses:
|
|
||||||
break
|
|
||||||
all_vgos += list(map(
|
|
||||||
lambda s: {
|
|
||||||
'id': s['id'],
|
|
||||||
'uri': s['uri'],
|
|
||||||
'content': s['content'],
|
|
||||||
'replies_count': s['replies_count'],
|
|
||||||
#'replies': mastodon.status_context(s['id']) if s['replies_count'] > 0 else [],
|
|
||||||
'created': s['created_at'],
|
|
||||||
'reblogs': s['reblogs_count'],
|
|
||||||
'favourites': s['favourites_count'],
|
|
||||||
'media': s['media_attachments']
|
|
||||||
}
|
|
||||||
, statuses))
|
|
||||||
last_id = statuses[-1]['id']
|
|
||||||
|
|
||||||
#print(all_vgos)
|
with open('oloturiadump.json', 'w') as json_file:
|
||||||
#print(json.dumps(all_vgos, default=default))
|
json.dump(all_vgos, json_file, indent=4, default=default)
|
||||||
|
|
||||||
with open('oloturiadump.json', 'w') as json_file:
|
|
||||||
json.dump(all_vgos, json_file, indent=4, default=default)
|
|
||||||
|
|
||||||
|
|
||||||
# Scarica tutte le immagini
|
# Scarica tutte le immagini
|
||||||
|
|
||||||
print("Scarico le immagini")
|
print("Scarico le immagini")
|
||||||
with open('oloturiadump.json') as json_file:
|
with open('oloturiadump.json') as json_file:
|
||||||
all_vgos = json.load(json_file)
|
all_vgos = json.load(json_file)
|
||||||
os.makedirs('media', exist_ok=True)
|
os.makedirs('media', exist_ok=True)
|
||||||
|
|
||||||
vgo_dict={}
|
vgo_dict={}
|
||||||
|
|
||||||
for vgo in all_vgos:
|
for vgo in all_vgos:
|
||||||
vgo_num = html2text.html2text(vgo['content']).split(' ')[0]
|
vgo_num = html2text.html2text(vgo['content']).split(' ')[0]
|
||||||
vgo_name = os.linesep.join([s for s in html2text.html2text(vgo['content']).splitlines() if s]).splitlines()[-1]
|
vgo_name = os.linesep.join([s for s in html2text.html2text(vgo['content']).splitlines() if s]).splitlines()[-1]
|
||||||
#print(vgo_num +' - '+ vgo_name)
|
#print(vgo_num +' - '+ vgo_name)
|
||||||
#print(str(vgo['id']) +' '+ vgo['uri'])
|
#print(str(vgo['id']) +' '+ vgo['uri'])
|
||||||
vgo_dict[vgo_num] = vgo_name
|
vgo_dict[vgo_num] = vgo_name
|
||||||
|
|
||||||
for media in vgo['media']:
|
|
||||||
#print(str(media['id']) +' '+ media['url'])
|
|
||||||
|
|
||||||
ext = os.path.splitext(media['preview_url'])[1]
|
|
||||||
img_name = os.path.join('media',str(media['id']) + ext)
|
|
||||||
|
|
||||||
if not os.path.isfile(img_name):
|
|
||||||
print(img_name)
|
|
||||||
img_data = requests.get(media['preview_url']).content
|
|
||||||
with open(img_name, 'wb') as handler:
|
|
||||||
handler.write(img_data)
|
|
||||||
|
|
||||||
with open('template.html') as html_file:
|
|
||||||
html_base = html_file.read()
|
|
||||||
with open('mediagallery.html') as html_file:
|
|
||||||
html_mediagallery = html_file.read()
|
|
||||||
|
|
||||||
|
|
||||||
# Genera i PDF
|
|
||||||
|
|
||||||
print("Genero i PDF")
|
|
||||||
os.makedirs('pdf', exist_ok=True)
|
|
||||||
for vgo in all_vgos:
|
|
||||||
vgo_num = html2text.html2text(vgo['content']).split(' ')[0]
|
|
||||||
vgo_name = os.linesep.join([s for s in html2text.html2text(vgo['content']).splitlines() if s]).splitlines()[-1]
|
|
||||||
|
|
||||||
html_name = 'oloturia.html'
|
|
||||||
pdf_name = os.path.join('pdf', vgo_num + '.pdf')
|
|
||||||
|
|
||||||
if not os.path.isfile(pdf_name):
|
|
||||||
print(vgo_num +' - '+ vgo_name)
|
|
||||||
|
|
||||||
|
|
||||||
media_num = 0
|
|
||||||
mediagallery_tot = ''
|
|
||||||
media_tot = len(vgo['media'])
|
|
||||||
|
|
||||||
sizes = "622px" if media_tot == 1 else "311px"
|
|
||||||
style = [
|
|
||||||
["inset: auto; width: 100%; height: 100%;"],
|
|
||||||
["inset: auto 2px auto auto; width: 50%; height: 100%;","inset: auto auto auto 2px; width: 50%; height: 100%;"],
|
|
||||||
["inset: auto 2px auto auto; width: 50%; height: 100%;","inset: auto auto 2px 2px; width: 50%; height: 50%;","inset: 2px auto auto 2px; width: 50%; height: 50%;"],
|
|
||||||
["inset: auto 2px 2px auto; width: 50%; height: 50%;","inset: auto auto 2px 2px; width: 50%; height: 50%;","inset: 2px 2px auto auto; width: 50%; height: 50%;","inset: 2px auto auto 2px; width: 50%; height: 50%;"]
|
|
||||||
]
|
|
||||||
|
|
||||||
for media in vgo['media']:
|
for media in vgo['media']:
|
||||||
mediagallery = html_mediagallery
|
#print(str(media['id']) +' '+ media['url'])
|
||||||
ext = os.path.splitext(media['url'])[1]
|
|
||||||
|
ext = os.path.splitext(media['preview_url'])[1]
|
||||||
img_name = os.path.join('media',str(media['id']) + ext)
|
img_name = os.path.join('media',str(media['id']) + ext)
|
||||||
mediagallery = mediagallery.replace("[media]", img_name)
|
|
||||||
mediagallery = mediagallery.replace("[style]", style[media_tot-1][media_num])
|
|
||||||
mediagallery = mediagallery.replace("[sizes]", sizes)
|
|
||||||
mediagallery_tot = mediagallery_tot + mediagallery
|
|
||||||
media_num = media_num + 1
|
|
||||||
|
|
||||||
content = html_base
|
if not os.path.isfile(img_name):
|
||||||
content = content.replace("[content]", vgo['content'])
|
print(img_name)
|
||||||
content = content.replace("[date]", datetime.datetime.fromisoformat(vgo['created']).strftime("%-d %B %Y, %H:%M"))
|
img_data = requests.get(media['preview_url']).content
|
||||||
content = content.replace("[reply]", str(vgo['replies_count']))
|
with open(img_name, 'wb') as handler:
|
||||||
content = content.replace("[reblogs]", str(vgo['reblogs']))
|
handler.write(img_data)
|
||||||
content = content.replace("[favourites]", str(vgo['favourites']))
|
|
||||||
content = content.replace("[mediagallery]", mediagallery_tot)
|
|
||||||
|
|
||||||
with open(html_name, 'w') as handler:
|
with open('template.html') as html_file:
|
||||||
handler.write(content)
|
html_base = html_file.read()
|
||||||
|
with open('mediagallery.html') as html_file:
|
||||||
|
html_mediagallery = html_file.read()
|
||||||
|
|
||||||
options = {
|
|
||||||
'page-size': 'A5',
|
# Genera i PDF
|
||||||
'margin-top': '0.5cm',
|
|
||||||
'margin-right': '0.5cm',
|
print("Genero i PDF")
|
||||||
'margin-bottom': '0.5cm',
|
os.makedirs('pdf', exist_ok=True)
|
||||||
'margin-left': '0.5cm',
|
for vgo in all_vgos:
|
||||||
'encoding': "UTF-8",
|
vgo_num = html2text.html2text(vgo['content']).split(' ')[0]
|
||||||
'quiet': ''
|
vgo_name = os.linesep.join([s for s in html2text.html2text(vgo['content']).splitlines() if s]).splitlines()[-1]
|
||||||
}
|
|
||||||
|
html_name = 'oloturia.html'
|
||||||
|
pdf_name = os.path.join('pdf', vgo_num + '.pdf')
|
||||||
|
|
||||||
|
if not os.path.isfile(pdf_name):
|
||||||
|
print(vgo_num +' - '+ vgo_name)
|
||||||
|
|
||||||
|
|
||||||
|
media_num = 0
|
||||||
|
mediagallery_tot = ''
|
||||||
|
media_tot = len(vgo['media'])
|
||||||
|
|
||||||
|
sizes = "622px" if media_tot == 1 else "311px"
|
||||||
|
style = [
|
||||||
|
["inset: auto; width: 100%; height: 100%;"],
|
||||||
|
["inset: auto 2px auto auto; width: 50%; height: 100%;","inset: auto auto auto 2px; width: 50%; height: 100%;"],
|
||||||
|
["inset: auto 2px auto auto; width: 50%; height: 100%;","inset: auto auto 2px 2px; width: 50%; height: 50%;","inset: 2px auto auto 2px; width: 50%; height: 50%;"],
|
||||||
|
["inset: auto 2px 2px auto; width: 50%; height: 50%;","inset: auto auto 2px 2px; width: 50%; height: 50%;","inset: 2px 2px auto auto; width: 50%; height: 50%;","inset: 2px auto auto 2px; width: 50%; height: 50%;"]
|
||||||
|
]
|
||||||
|
|
||||||
|
for media in vgo['media']:
|
||||||
|
mediagallery = html_mediagallery
|
||||||
|
ext = os.path.splitext(media['url'])[1]
|
||||||
|
img_name = os.path.join('media',str(media['id']) + ext)
|
||||||
|
mediagallery = mediagallery.replace("[media]", img_name)
|
||||||
|
mediagallery = mediagallery.replace("[style]", style[media_tot-1][media_num])
|
||||||
|
mediagallery = mediagallery.replace("[sizes]", sizes)
|
||||||
|
mediagallery_tot = mediagallery_tot + mediagallery
|
||||||
|
media_num = media_num + 1
|
||||||
|
|
||||||
|
content = html_base
|
||||||
|
content = content.replace("[content]", vgo['content'])
|
||||||
|
content = content.replace("[date]", datetime.datetime.fromisoformat(vgo['created']).strftime("%-d %B %Y, %H:%M"))
|
||||||
|
content = content.replace("[reply]", str(vgo['replies_count']))
|
||||||
|
content = content.replace("[reblogs]", str(vgo['reblogs']))
|
||||||
|
content = content.replace("[favourites]", str(vgo['favourites']))
|
||||||
|
content = content.replace("[mediagallery]", mediagallery_tot)
|
||||||
|
|
||||||
|
with open(html_name, 'w') as handler:
|
||||||
|
handler.write(content)
|
||||||
|
|
||||||
|
options = {
|
||||||
|
'page-size': 'A5',
|
||||||
|
'margin-top': '0.5cm',
|
||||||
|
'margin-right': '0.5cm',
|
||||||
|
'margin-bottom': '0.5cm',
|
||||||
|
'margin-left': '0.5cm',
|
||||||
|
'encoding': "UTF-8",
|
||||||
|
'quiet': ''
|
||||||
|
}
|
||||||
|
|
||||||
|
try:
|
||||||
|
pdfkit.from_file(html_name, pdf_name, options=options)
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
|
||||||
|
os.remove(html_name)
|
||||||
|
|
||||||
|
|
||||||
|
# Genera i libretti
|
||||||
|
|
||||||
|
print("Genero i libretti")
|
||||||
|
os.makedirs('books', exist_ok=True)
|
||||||
|
for book_num in range(1, int(len(vgo_dict) / 50) + 1):
|
||||||
|
pdfWriter = PyPDF2.PdfFileWriter()
|
||||||
|
print(book_num)
|
||||||
|
|
||||||
|
pagstart = (book_num - 1) * 50 + 1
|
||||||
|
pagend = book_num * 50
|
||||||
|
|
||||||
|
# aggiungere copertina
|
||||||
|
pdfWriter.addPage(copertina(str(pagstart).zfill(3) + " - " + str(pagend).zfill(3)))
|
||||||
|
|
||||||
|
for vgo_num in [str(x).zfill(3) for x in range(pagstart, pagend + 1)]:
|
||||||
|
pdf_name = os.path.join('pdf', vgo_num + '.pdf')
|
||||||
|
|
||||||
try:
|
try:
|
||||||
pdfkit.from_file(html_name, pdf_name, options=options)
|
#print(vgo_num + " - " + vgo_dict[vgo_num])
|
||||||
|
pdfFileObj = open(pdf_name, 'rb')
|
||||||
|
pdfReader = PyPDF2.PdfFileReader(pdfFileObj)
|
||||||
|
pageObj = pdfReader.getPage(0)
|
||||||
|
pdfWriter.addPage(pageObj)
|
||||||
except:
|
except:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
os.remove(html_name)
|
# aggiungere indice ed eventualmente pagina finale
|
||||||
|
|
||||||
|
book_name = os.path.join('books', 'book' + str(book_num).zfill(2) + '.pdf')
|
||||||
# Genera i libretti
|
with open(book_name, 'wb') as pdfOutput:
|
||||||
|
pdfWriter.write(pdfOutput)
|
||||||
print("Genero i libretti")
|
|
||||||
os.makedirs('books', exist_ok=True)
|
|
||||||
for book_num in range(1, int(len(vgo_dict) / 50) + 1):
|
|
||||||
pdfWriter = PyPDF2.PdfFileWriter()
|
|
||||||
print(book_num)
|
|
||||||
|
|
||||||
pagstart = (book_num - 1) * 50 + 1
|
|
||||||
pagend = book_num * 50
|
|
||||||
|
|
||||||
# aggiungere copertina
|
|
||||||
pdfWriter.addPage(copertina(str(pagstart).zfill(3) + " - " + str(pagend).zfill(3)))
|
|
||||||
|
|
||||||
for vgo_num in [str(x).zfill(3) for x in range(pagstart, pagend + 1)]:
|
|
||||||
pdf_name = os.path.join('pdf', vgo_num + '.pdf')
|
|
||||||
|
|
||||||
try:
|
|
||||||
#print(vgo_num + " - " + vgo_dict[vgo_num])
|
|
||||||
pdfFileObj = open(pdf_name, 'rb')
|
|
||||||
pdfReader = PyPDF2.PdfFileReader(pdfFileObj)
|
|
||||||
pageObj = pdfReader.getPage(0)
|
|
||||||
pdfWriter.addPage(pageObj)
|
|
||||||
except:
|
|
||||||
pass
|
|
||||||
|
|
||||||
# aggiungere indice ed eventualmente pagina finale
|
|
||||||
|
|
||||||
book_name = os.path.join('books', 'book' + str(book_num).zfill(2) + '.pdf')
|
|
||||||
with open(book_name, 'wb') as pdfOutput:
|
|
||||||
pdfWriter.write(pdfOutput)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
main()
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue