2021-02-26 15:50:02 +01:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
|
|
|
|
import os.path
|
2021-12-21 20:21:04 +01:00
|
|
|
from qrcode import make as qrcode_make
|
2021-02-26 15:50:02 +01:00
|
|
|
import qrcode.image.svg
|
2021-12-18 22:30:16 +01:00
|
|
|
from svgutils import transform as st
|
|
|
|
from ch_kreuz import swisscross as get_swisscross
|
2021-12-19 08:39:14 +01:00
|
|
|
from ch_kreuz import white as get_white
|
|
|
|
from svgutils.compose import Figure
|
2021-12-21 20:21:04 +01:00
|
|
|
from chardet import detect
|
2021-12-19 08:39:14 +01:00
|
|
|
|
2021-02-26 15:50:02 +01:00
|
|
|
|
|
|
|
class qr_rechnung():
|
|
|
|
data = ''
|
|
|
|
error_correction = None
|
|
|
|
|
|
|
|
def __init__(self, data=None, textfile=None):
|
|
|
|
if textfile is not None:
|
|
|
|
self.set_data_from_textfile(textfile)
|
|
|
|
|
|
|
|
def set_data(self, data):
|
|
|
|
self.data = data
|
2021-12-21 20:21:04 +01:00
|
|
|
self.data = data.encode('latin-1')
|
2021-02-26 15:50:02 +01:00
|
|
|
|
|
|
|
def set_data_from_textfile(self, textfile):
|
2021-12-21 20:21:04 +01:00
|
|
|
with open(textfile, 'rb') as rawdata:
|
|
|
|
charenc = detect(rawdata.read())['encoding']
|
|
|
|
with open(textfile, 'r', encoding=charenc) as f:
|
|
|
|
self.set_data(f.read())
|
2021-02-26 15:50:02 +01:00
|
|
|
|
|
|
|
def write_file(self, filepath, force=False):
|
|
|
|
global qrcode
|
|
|
|
mode = 'w' if force else 'x'
|
|
|
|
try:
|
|
|
|
assert force or not os.path.isfile(filepath)
|
|
|
|
img = qrcode.make(
|
|
|
|
self.data,
|
|
|
|
error_correction=qrcode.constants.ERROR_CORRECT_M,
|
|
|
|
image_factory=qrcode.image.svg.SvgPathImage
|
|
|
|
)
|
|
|
|
img.save(filepath)
|
|
|
|
except AssertionError:
|
|
|
|
print(f"ERROR: Datei {filepath} existiert bereits.")
|
|
|
|
return 1
|
|
|
|
|
|
|
|
qrcode = st.fromfile(filepath)
|
2021-12-19 08:39:14 +01:00
|
|
|
try:
|
|
|
|
assert qrcode.width[-2:] == 'mm'
|
|
|
|
qr_scale = 49.5/float(qrcode.width[:-2])
|
|
|
|
except AssertionError as e:
|
|
|
|
print(f"ERROR: Ein unerwarteter Fall in der Skallierung.")
|
|
|
|
print(e)
|
|
|
|
return 1
|
2021-02-26 15:50:02 +01:00
|
|
|
|
2021-12-19 08:39:14 +01:00
|
|
|
qrr = Figure(
|
|
|
|
'49.5mm', '49.5mm',
|
|
|
|
get_white().getroot(),
|
|
|
|
qrcode.getroot().scale(qr_scale),
|
|
|
|
get_swisscross().getroot()
|
|
|
|
)
|
|
|
|
qrr.save(filepath)
|
2021-02-26 15:50:02 +01:00
|
|
|
|
|
|
|
|
|
|
|
def help(args):
|
2021-12-19 08:39:14 +01:00
|
|
|
return '\n'.join([
|
|
|
|
'{0}: Ungültige Eingabe',
|
|
|
|
'Aufruf: {0} TEXTDATEI [SVG-ZIELDATEI]',
|
|
|
|
]).format(args[0])
|
2021-02-26 15:50:02 +01:00
|
|
|
|
|
|
|
|
|
|
|
def main(args):
|
|
|
|
try:
|
|
|
|
textfile = args[1]
|
|
|
|
except IndexError:
|
|
|
|
print(help(args))
|
|
|
|
return 1
|
|
|
|
try:
|
2021-12-19 08:39:14 +01:00
|
|
|
output_format = 'svg'
|
2021-02-26 15:50:02 +01:00
|
|
|
svgfile = args[2]
|
2021-12-19 08:39:14 +01:00
|
|
|
if svgfile[-4:] == '.svg':
|
|
|
|
pass
|
|
|
|
else:
|
|
|
|
svgfile += '.svg'
|
2021-02-26 15:50:02 +01:00
|
|
|
except IndexError:
|
|
|
|
try:
|
|
|
|
assert textfile[-4:] == '.txt'
|
|
|
|
svgfile = textfile[:-4]+'.svg'
|
|
|
|
except AssertionError:
|
|
|
|
print(help(args))
|
|
|
|
return 1
|
|
|
|
try:
|
|
|
|
x = qr_rechnung(textfile=textfile)
|
|
|
|
x.write_file(svgfile, force=False)
|
|
|
|
except (PermissionError, FileNotFoundError) as e:
|
|
|
|
print(e)
|
|
|
|
return 1
|
2021-12-19 08:39:14 +01:00
|
|
|
if output_format == 'svg':
|
|
|
|
return 0
|
|
|
|
else:
|
|
|
|
print(f"ERROR: Unbekanntes Output_format: {output_format}")
|
|
|
|
return 1
|
2021-02-26 15:50:02 +01:00
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
import sys
|
|
|
|
sys.exit(main(sys.argv))
|