Files
Nuliga2/NuLiga_working.ipynb
2025-09-03 14:09:15 +02:00

425 lines
17 KiB
Plaintext

{
"cells": [
{
"cell_type": "code",
"execution_count": 1,
"metadata": {},
"outputs": [],
"source": [
"# Imports \n",
"import os\n",
"import sys\n",
"import subprocess\n",
"import time\n",
"import dateutil.parser\n",
"from ids import *\n",
"#from hallen import *\n",
"import locale\n",
"import re\n",
"import requests\n",
"from bs4 import BeautifulSoup\n",
"import tabulate\n",
"#NummerDJugend=10\n",
"#%run ./QR_parser.ipynb"
]
},
{
"cell_type": "code",
"execution_count": 2,
"metadata": {},
"outputs": [],
"source": [
"tex_code = r\"\"\"\n",
"\\documentclass[12pt,a4paper,landscape]{extarticle}\n",
"\\usepackage[T1]{fontenc}\n",
"\\usepackage[default]{opensans}\n",
"\\usepackage[utf8]{inputenc}\n",
"\\usepackage[table]{xcolor}\n",
"\\usepackage[margin=0.01in]{geometry}\n",
"\\usepackage{array}\n",
"\\usepackage{arev}\n",
"%\\usepackage[T1]{fontenc}\n",
"\\usepackage{scalefnt}\n",
"\\usepackage{caption}\n",
"\\usepackage{array}\n",
"\\usepackage{graphicx}\n",
"\\usepackage[absolute]{textpos}\n",
"\\usepackage{threeparttable}\n",
"\\newcolumntype{L}[1]{>{\\raggedright\\let\\newline\\\\\\arraybackslash\\hspace{0pt}}m{#1}}\n",
"\\newcolumntype{C}[1]{>{\\centering\\let\\newline\\\\\\arraybackslash\\hspace{0pt}}m{#1}}\n",
"\\newcolumntype{R}[1]{>{\\raggedleft\\let\\newline\\\\\\arraybackslash\\hspace{0pt}}m{#1}}\n",
"\\makeatletter\n",
"\\newcommand{\\thickhline}{%\n",
" \\noalign {\\ifnum 0=`}\\fi \\hrule height 2pt\n",
" \\futurelet \\reserved@a \\@xhline\n",
"}\n",
"\\setlength{\\tabcolsep}{.16667em}\n",
"\\newcolumntype{\"}{@{\\hskip\\tabcolsep\\vrule width 2pt\\hskip\\tabcolsep}}\n",
"\\makeatother\n",
"\\usepackage{color, colortbl}\n",
"\\definecolor{LRed}{rgb}{1,.8,.8}\n",
"\\definecolor{LGreen}{rgb}{.8,1,.8}\n",
"\\definecolor{LBlue}{rgb}{8,39,142}\n",
"\\renewcommand{\\rmdefault}{ptm}\n",
"\\setlength{\\topmargin}{-2.5cm}\n",
"\\begin{document}\"\"\""
]
},
{
"cell_type": "code",
"execution_count": 8,
"metadata": {
"scrolled": true
},
"outputs": [
{
"ename": "NameError",
"evalue": "name 'spiele' is not defined",
"output_type": "error",
"traceback": [
"\u001b[31m---------------------------------------------------------------------------\u001b[39m",
"\u001b[31mNameError\u001b[39m Traceback (most recent call last)",
"\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[8]\u001b[39m\u001b[32m, line 104\u001b[39m\n\u001b[32m 102\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m team[y][\u001b[32m0\u001b[39m] == verein:\n\u001b[32m 103\u001b[39m verein=\u001b[33m'\u001b[39m\u001b[38;5;130;01m\\\\\u001b[39;00m\u001b[33mtextbf\u001b[39m\u001b[33m{\u001b[39m\u001b[33m'\u001b[39m+verein+\u001b[33m'\u001b[39m\u001b[33m}\u001b[39m\u001b[33m'\u001b[39m\n\u001b[32m--> \u001b[39m\u001b[32m104\u001b[39m spiele = \u001b[33m'\u001b[39m\u001b[38;5;130;01m\\\\\u001b[39;00m\u001b[33mtextbf\u001b[39m\u001b[33m{\u001b[39m\u001b[33m'\u001b[39m + \u001b[43mspiele\u001b[49m + \u001b[33m'\u001b[39m\u001b[33m}\u001b[39m\u001b[33m'\u001b[39m\n\u001b[32m 105\u001b[39m siege = \u001b[33m'\u001b[39m\u001b[38;5;130;01m\\\\\u001b[39;00m\u001b[33mtextbf\u001b[39m\u001b[33m{\u001b[39m\u001b[33m'\u001b[39m + siege + \u001b[33m'\u001b[39m\u001b[33m}\u001b[39m\u001b[33m'\u001b[39m\n\u001b[32m 106\u001b[39m unentschieden = \u001b[33m'\u001b[39m\u001b[38;5;130;01m\\\\\u001b[39;00m\u001b[33mtextbf\u001b[39m\u001b[33m{\u001b[39m\u001b[33m'\u001b[39m + unentschieden + \u001b[33m'\u001b[39m\u001b[33m}\u001b[39m\u001b[33m'\u001b[39m\n",
"\u001b[31mNameError\u001b[39m: name 'spiele' is not defined"
]
}
],
"source": [
"for y in range(len(team)):\n",
"#for y in range(10):\n",
" #print('Y=',y)\n",
" #print(team[y])\n",
" #print(y)\n",
" #print(team)\n",
" try: \n",
" table=tabelle(team[y])\n",
" except: \n",
" print('Table ', team[y][1], ' failed')\n",
" try:\n",
" Teamspielplan=teamspielplan(team[y])\n",
" except:\n",
" print('Teamspielplan ', team[y][1], 'failed')\n",
" parse=re.compile(r\"([K|L]\\w*\\s\\d?)\")\n",
" Liga=getliga(team[y])\n",
" #print(y, team[y])\n",
" tex_code += r\"\"\"\n",
" \\begin{textblock}{3}(0,13.2)\n",
" \\begin{figure}\n",
" \\includegraphics[width=3cm]{\"\"\"+team[y][Shortname]\n",
" tex_code += r\"\"\"}\\\\\\centering\n",
" Link zur liga\\end{figure}\\end{textblock}\n",
" \\begin{center}\n",
" \\vspace{0cm}\n",
" {\\scalefont{3}\"\"\"\n",
" tex_code +=r\"{}\".format(team[y][Alias])\n",
" tex_code +=r\"\"\"}\\\\\\scalefont{2}\"\"\"\n",
" if y<14:\n",
" tex_code +=r\"{}\".format(Liga)\n",
" tex_code +=r\"\"\"\\\\\"\"\"\n",
" tex_code +=r\"\"\"\n",
" \\vspace{0cm}\n",
" \\end{center}\n",
" \\rowcolors{2}{gray!25}{white}\n",
" \\begin{table}[h]\"\"\"\n",
" tex_code +=r\"\"\"\\small\n",
" \"\"\"\n",
" tex_code +=r\"\"\"\\centering\"\"\"\n",
" if len(table[0]) == 9:\n",
" tex_code +=r\"\"\"\\begin{tabular}{|L{0.6cm}|L{4.3cm}|C{1.2cm}|C{0.5cm}|C{0.4cm}|C{0.5cm}|C{1.5cm}|C{1.2cm}|C{1.3cm}|}\"\"\"\n",
" tex_code +=r\"\"\"\\hline\n",
" \\rowcolor{gray!50}\"\"\"\n",
" tex_code +=r\"\"\"Nr. & Mannschaft &Spiele& S & U &N & Tore & diff. & Punkte\\\\\"\"\"\n",
" if len(table[0]) == 7:\n",
" tex_code +=r\"\"\"\\begin{tabular}{|L{0.6cm}|L{5.5cm}|C{1.3cm}|C{0.5cm}|C{0.4cm}|C{0.5cm}|C{1.5cm}|}\"\"\"\n",
" tex_code +=r\"\"\"\\hline\n",
" \\rowcolor{gray!50}\"\"\"\n",
" tex_code +=r\"\"\"Nr. & Mannschaft &Spiele& S & U &N & Punkte\\\\\"\"\"\n",
" if len(table[0]) == 3:\n",
" tex_code +=r\"\"\"\\begin{tabular}{|L{5.5cm}|}\"\"\"\n",
" tex_code +=r\"\"\"\\hline\n",
" \\rowcolor{gray!50}\"\"\"\n",
" tex_code +=r\"\"\"Mannschaft\\\\\"\"\"\n",
" tex_code +=r\"\"\"\\hline \"\"\"\n",
" for x in range(len(table)):\n",
" verein = Teamspielplan_kuerzen(table[x][1])\n",
" rank = table[x][0]\n",
"\n",
" if len(table[x]) > 3:\n",
" if len(table[x][3]) < 3:\n",
" spiele =table[x][2]\n",
" else:\n",
" spiele = '-'\n",
" try: \n",
" if len(table[x][3]) < 3:\n",
" siege = table[x][3]\n",
" else: \n",
" siege = '-'\n",
" except:\n",
" siege = '0'\n",
" if table[x][3].startswith('zur') or table[x][2].startswith('zur'):\n",
" break\n",
" if len(table[0]) > 3:\n",
" try: \n",
" unentschieden = table[x][4]\n",
" niederlagen = table[x][5]\n",
" except:\n",
" unentschieden ='-'\n",
" niederlagen = '-'\n",
" if len(table[0]) > 7:\n",
" try:\n",
" tore = table[x][6]\n",
" diff = table[x][7]\n",
" punkte = table[x][8]\n",
" except:\n",
" tore = '-'\n",
" diff = '-'\n",
" punkte = '-'\n",
" if len(table[0]) == 7: \n",
" try:\n",
" punkte = table[x][6]\n",
" tore = '-'\n",
" diff = '-'\n",
" except:\n",
" punkte = '-'\n",
" print('Tabellenlänge falsch: '+team[y][1])\n",
" print(table)\n",
" #spiele=\"\\multicolumn{4}{|c|}{\"+table[x][2]+\"}\"\n",
" rank = '\\\\textbf{' + rank + '}'\n",
" #if \"Eschweiler\" in verein:\n",
" if team[y][0] == verein:\n",
" verein='\\\\textbf{'+verein+'}'\n",
" spiele = '\\\\textbf{' + spiele + '}'\n",
" siege = '\\\\textbf{' + siege + '}'\n",
" unentschieden = '\\\\textbf{' + unentschieden + '}'\n",
" niederlagen = '\\\\textbf{' + niederlagen + '}'\n",
" tore = '\\\\textbf{' + tore + '}'\n",
" diff = '\\\\textbf{' + diff + '}'\n",
" punkte = '\\\\textbf{' + punkte + '}'\n",
" if len(table[0]) == 9:\n",
" tex_code += r\"\"\"{}&{}&{}&{}&{}&{}&{}&{}&{}\\\\\"\"\".format(rank,verein, spiele,siege,unentschieden,niederlagen,tore,diff,punkte)\n",
" if len(table[0]) == 7:\n",
" tex_code += r\"\"\"{}&{}&{}&{}&{}&{}&{}\\\\\"\"\".format(rank,verein, spiele,siege,unentschieden,niederlagen,punkte)\n",
" if len(table[0]) == 3:\n",
" tex_code += r\"\"\"{}\\\\\"\"\".format(verein)\n",
" tex_code += os.linesep\n",
" tex_code+=r\"\"\"\n",
" \\hline\n",
" \\end{tabular}\"\"\"\n",
" tex_code+=r\"\"\"\\hspace*{0.3cm}\"\"\"\n",
" if len(table[0]) > 3:\n",
" tex_code+=r\"\"\"\n",
" \\begin{tabular}{|C{0.65cm}|C{2cm}|C{1.0cm}|C{4.1cm}|C{4.1cm}|C{1.2cm}|C{1.4cm}|}\n",
" \\hline\n",
" \\rowcolor{gray!50}\n",
" Tag & Datum & Zeit& Heim & Gast & Erg.& Halle\\\\\n",
" \"\"\"\n",
" if len(table[0]) == 3:\n",
" tex_code+=r\"\"\"\n",
" \\begin{tabular}{|C{0.65cm}|C{2cm}|C{1.0cm}|C{4.1cm}|C{4.1cm}|C{1.4cm}|}\n",
" \\hline\n",
" \\rowcolor{gray!50}\n",
" Tag & Datum & Zeit& Heim & Gast & Halle\\\\\n",
" \"\"\"\n",
" \n",
" for x in range(len(Teamspielplan)):\n",
" tag = Teamspielplan[x][0]\n",
" if tag == 'Termin offen':\n",
" tag = ' '\n",
" Teamspielplan[x][0]='offen'\n",
" Teamspielplan[x].insert(0,'')\n",
" zeit = Teamspielplan[x][2].lstrip()\n",
" #try:\n",
" # zeit = Teamspielplan[x][2]\n",
" #except: \n",
" # zeit = Teamspielplan[x][2].replace('v', '') \n",
" if zeit == '00:00':\n",
" zeit = ''\n",
" datum = Teamspielplan[x][1]\n",
" heim = Teamspielplan_kuerzen(Teamspielplan[x][5])\n",
" gast = Teamspielplan_kuerzen(Teamspielplan[x][6])\n",
" if team[y][0] == heim:\n",
" heim='\\\\textbf{'+team[y][0]+'}'\n",
" if team[y][0] == gast:\n",
" gast='\\\\textbf{'+team[y][0]+'}'\n",
" turnhalle = Teamspielplan[x][3]\n",
" ergebnis = Teamspielplan[x][7]\n",
" #print(ergebnis)\n",
" if \"spielfrei\" in gast or \"spielfrei\" in heim:\n",
" continue\n",
" if len(table[0]) > 3:\n",
" tex_code += r\"{}&{}&{}&{}&{}&{}&{}\\\\\".format(tag,datum,zeit[0:5],heim,gast,ergebnis,halle(turnhalle))\n",
" tex_code += os.linesep\n",
" if len(table[0]) == 3:\n",
" tex_code += r\"{}&{}&{}&{}&{}&{}\\\\\".format(tag,datum,zeit[0:5],heim,gast,halle(turnhalle))\n",
" tex_code += os.linesep\n",
" tex_code+=r\"\"\"\n",
" \\hline\n",
" \\end{tabular}\"\"\"\n",
" tex_code+=r\"\"\"\n",
" \\end{table}\"\"\"\n",
" erklaerung =''\n",
" if any('NG' in sublist for sublist in Teamspielplan):\n",
" erklaerung += '\\\\textbf{NG} = Gastmannschaft nicht angetreten' \n",
" if any('NH' in sublist for sublist in Teamspielplan):\n",
" if erklaerung != '':\n",
" erklaerung += '; '\n",
" erklaerung += '\\\\textbf{NH} = Heimmannschaft nicht angetreten' \n",
" if any('WG' in sublist for sublist in Teamspielplan):\n",
" if erklaerung != '':\n",
" erklaerung += '; '\n",
" erklaerung += '\\\\textbf{WG} = Wertung für Heimmannschaft' \n",
" if any('WH' in sublist for sublist in Teamspielplan):\n",
" if erklaerung != '':\n",
" erklaerung += '; '\n",
" erklaerung += '\\\\textbf{WH} = Wertung für Auswärtsmannschaft' \n",
" if any('ZH' in sublist for sublist in Teamspielplan):\n",
" if erklaerung != '':\n",
" erklaerung += '; '\n",
" erklaerung += '\\\\textbf{ZH} = Heimmannschaft zurückgezogen'\n",
" if any('ZG' in sublist for sublist in Teamspielplan):\n",
" if erklaerung != '':\n",
" erklaerung += '; '\n",
" erklaerung += '\\\\textbf{ZG} = Gastmannschaft zurückgezogen'\n",
" if erklaerung != '':\n",
" tex_code+=r\"\"\"\\begin{textblock}{9}(7,15.5)\"\"\"\n",
" tex_code+=erklaerung\n",
" tex_code+=r\"\"\"\\end{textblock}\"\"\"\n",
" tex_code+=r\"\"\"\n",
" \\newpage\"\"\"\n",
"\n",
"tex_code += r\"\"\"\n",
"\\centering\n",
"\\scalefont{5}Die nächsten Spiele\\\\[0.5cm]\n",
"\\begin{table}[h]\n",
"\\centering\n",
"\\begin{tabular}{|p{3cm} R{10cm} p{0.5cm} p{10cm} p{4cm}|}\n",
"\\rowcolor{gray!50}\n",
"\"\"\"\n",
"minis=False\n",
"Spiele=naechsteSpiele(4)\n",
"Tage=0\n",
"spiele=0\n",
"for spiel in Spiele:\n",
" tag = spiel[0]\n",
" if tag == '' :\n",
" spiele=spiele+1\n",
" else: \n",
" Tage=Tage+1\n",
"#print(Tage)\n",
"#print(spiele)\n",
"if spiele > 18:\n",
" limit=Tage-1\n",
" #print(\"begrenzt\")\n",
"else:\n",
" limit = 8\n",
"#print(limit)\n",
"ctr=0\n",
"for spiel in Spiele:\n",
" tag = spiel[0]\n",
" datum = spiel[1]\n",
" uhrzeit = spiel[2]\n",
" if tag != '' :\n",
" ctr=ctr+1\n",
" if ctr>limit:\n",
" break\n",
" tex_code += r\"\"\"\\rowcolor{darkgray!50}\\hline\\multicolumn{5}{|l|}{{\\scalefont{2.5}\\textbf{\\textcolor{white}{\"\"\"\n",
" tex_code += r\"{}\".format(tag + '' + datum)\n",
" tex_code += r\"}}}}\\\\\"\n",
" tex_code += os.linesep\n",
" halle=spiel[3]\n",
" heim=spiel[6]\n",
" gast=spiel[7]\n",
" if (heim==\"spielfrei\") or (gast == \"spielfrei\"):\n",
" continue \n",
" if (heim==\"\\\\textbf{Minis}\") or (gast == \"\\\\textbf{Minis}\"):\n",
" if minis == True:\n",
" continue\n",
" if minis == False:\n",
" minis = True\n",
" #TEXT=\"Mini Turnier\"\n",
" tex_code += r'\\LARGE {'+uhrzeit[0:5]+r'}&\\multicolumn{3}{c}{\\LARGE \\\\textbf{ MINI Turnier}}&\\LARGE {'+ halle +r'}' \n",
" tex_code += r\"\\\\\"\n",
" tex_code += os.linesep\n",
" # 18 Lines\n",
" else:\n",
" # print bla.strftime(\"%d.%m.%Y %H:%M\"), heim,' - ', gast, halle, strasse, ort, gespann\n",
" tex_code += r\"\\LARGE {}&\\LARGE {} &\\LARGE :& \\LARGE {}&\\LARGE {}\\\\\".format(uhrzeit[0:5],heim,gast,halle)\n",
" tex_code += os.linesep\n",
"tex_code += r\"\"\"\n",
"\\hline\n",
"\\end{tabular}\n",
"\\end{table}\"\"\""
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": []
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": []
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": [
"tex_code+=r\"\"\"\n",
"\\end{document}\"\"\"\n",
"#print(tex_code)\n",
"tex_file = \"tabelle.tex\"\n",
"with open(tex_file, \"w\") as out_file:\n",
" out_file.write(tex_code)\n",
"print(\"done.\")\n",
"os.system(\"/usr/local/texlive/2025/bin/universal-darwin/pdflatex tabelle.tex\")\n",
"os.system(\"rm -f *.log *.aux\")"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": []
}
],
"metadata": {
"@webio": {
"lastCommId": null,
"lastKernelId": null
},
"kernel_info": {
"name": "ldap3-ipython"
},
"kernelspec": {
"display_name": "Python 3 (ipykernel)",
"language": "python",
"name": "python3"
},
"language_info": {
"codemirror_mode": {
"name": "ipython",
"version": 3
},
"file_extension": ".py",
"mimetype": "text/x-python",
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
"version": "3.13.6"
},
"nteract": {
"version": "0.15.0"
}
},
"nbformat": 4,
"nbformat_minor": 4
}