425 lines
17 KiB
Plaintext
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
|
|
}
|