From cdcfdba82e5bbaf6be4dcdd02f4fc714eb2f9b20 Mon Sep 17 00:00:00 2001 From: francesco Date: Tue, 20 Jan 2026 15:16:50 +0100 Subject: [PATCH] Update cemento.py --- cemento.py | 18 +++++++----------- 1 file changed, 7 insertions(+), 11 deletions(-) diff --git a/cemento.py b/cemento.py index e7b9e55..57a1fc2 100644 --- a/cemento.py +++ b/cemento.py @@ -11,7 +11,7 @@ def calcola(d): val = float(v.replace(',', '.')) if v else 0 return val / 1000 if u == "mm" else val / 100 if u == "cm" else val - # Dimensioni originali per il report + # Salvo le dimensioni originali per il report dim_orig = {"a": d.get('a','0'), "ua": d.get('ua','m'), "l": d.get('l','0'), "ul": d.get('ul','m'), "p": d.get('p','0'), "up": d.get('up','m')} vol = to_m(dim_orig['a'], dim_orig['ua']) * to_m(dim_orig['l'], dim_orig['ul']) * to_m(dim_orig['p'], dim_orig['up']) @@ -23,10 +23,9 @@ def calcola(d): c = {m: float(d.get(f'c_{m}', '0').replace(',','.')) for m in mats} somma_p = sum(p.values()) - # Calcolo percentuali proporzioni perc = {m: (p[m]/somma_p)*100 if somma_p > 0 else 0 for m in mats} - res = {"vol": f"{vol:.3f}", "peso": f"{peso_tot:.0f}", "perc": perc, "dim": dim_orig} + res = {"vol": f"{vol:.3f}", "peso": f"{peso_tot:.0f}", "perc": perc, "dim": dim_orig, "parti": p} tot_s, costo_t = 0, 0 for m in mats: @@ -77,19 +76,16 @@ def esegui_stampa_cups(f): 70 620 moveto (COSTO TOTALE: {f.get('res_costo_t')} Euro) show 70 600 moveto (PROPORZIONI) show /Helvetica findfont 10 scalefont setfont -70 585 moveto (Cemento: {f.get('p_cem')} ({f.get('pc_cem')}%) | Sabbia: {f.get('p_sab')} ({f.get('pc_sab')}%) | Ghiaia: {f.get('p_ghi')} ({f.get('pc_ghi')}%)) show -/Helvetica-Bold findfont 11 scalefont setfont +70 585 moveto (Cem: {f.get('p_cem')} ({f.get('pc_cem')}%) | Sab: {f.get('p_sab')} ({f.get('pc_sab')}%) | Ghi: {f.get('p_ghi')} ({f.get('pc_ghi')}%)) show 70 560 moveto (PER OGNI CARICO ({f.get('res_nc')} CARICHI):) show -/Helvetica findfont 10 scalefont setfont 70 545 moveto (o Cemento: {f.get('res_bc_cem')} sacchetti) show 70 530 moveto (o Sabbia: {f.get('res_bc_sab')} sacchetti) show 70 515 moveto (o Ghiaia: {f.get('res_bc_ghi')} sacchetti) show 70 500 moveto (o Acqua: {f.get('res_bc_aq')} L) show showpage""" - comando = ["docker", "exec", "-i", "cups-pdf-server", "lp", "-d", "Virtual_PDF"] - subprocess.run(comando, input=ps_content.encode('utf-8'), capture_output=True) + subprocess.run(["docker", "exec", "-i", "cups-pdf-server", "lp", "-d", "Virtual_PDF"], input=ps_content.encode('utf-8')) return "OK - PDF generato in /output!" - except Exception as e: return f"Errore: {str(e)}" + except: return "Errore di stampa" @app.route('/download', methods=['POST']) def download(): @@ -105,8 +101,8 @@ def download(): f"• Acqua: \t{f.get('res_aq')} L | Totale: {f.get('res_tot_s')} sacch.\n\n" f"COSTO TOTALE: \t{f.get('res_costo_t')} €\n\n" f"PROPORZIONI\n" - f"Cemento: {f.get('p_cem')} Sabbia: {f.get('p_sab')} Ghiaia: {f.get('p_ghi')}\n" - f"{f.get('pc_cem')}% \t {f.get('pc_sab')}% \t {f.get('pc_ghi')}%\n\n" + f"Cemento: {f.get('p_cem')} \tSabbia: {f.get('p_sab')} \tGhiaia: {f.get('p_ghi')}\n" + f"Cemento: {f.get('pc_cem')}% \tSabbia: {f.get('pc_sab')}% \tGhiaia: {f.get('pc_ghi')}%\n\n" f"PER OGNI CARICO ({f.get('res_nc')} CARICHI):\n\n" f"• Cemento: \t{f.get('res_bc_cem')} sacchetti\n" f"• Sabbia: \t{f.get('res_bc_sab')} sacchetti\n"