diff --git a/app/app.py b/app/app.py index 87a3aec..09aa5d8 100644 --- a/app/app.py +++ b/app/app.py @@ -12,18 +12,29 @@ st.set_page_config( # the same favicon and if posting links for example in whatsapp they will have the same title page_title="tebarius Mysteryhelfer (web)", page_icon="images/favicon.ico", - layout="wide" + layout="wide", + menu_items={ + 'About': '### tebarius Mysteryhelfer (web)\n' + 'Dies ist die Umsetzung der [Desktop-App Mysteryhelfer](https://mysteryhelfer.tebarius.duckdns.org/) ' + '([Source](https://gitea.tebarius.duckdns.org/tebarius/Mysteryhelfer)) als Web-App. \n \n' + 'Für die Umsetzung kommt das Python-Framework [Streamlit](https://streamlit.io/) zum Einsatz. \n \n' + '_Der Sourcecode und Docker-Images zum selbst hosten sind auf_ ' + '_https://gitea.tebarius.duckdns.org/tebarius/Mysteryhelfer-web verfügbar._ \n \n' + 'Anregungen, Hinweise, Fehlerreports gerne an: ' + '[tba@gmx.li](mailto:tba@gmx.li?subject=Mysteryhelfer-web) oder über einen Logeintrag beim ' + '[App-TB](https://www.geocaching.com/track/details.aspx?tracker=arx57k) ' + '(trackbar auf geocaching.com).', + } ) -st.logo('images/logo.png', size='large') +st.logo('images/logo.png', size='large', link='https://gitea.tebarius.duckdns.org/tebarius/Mysteryhelfer-web') logo_col, title_col = st.columns([1,4]) with logo_col: - st.markdown(f'' + st.markdown(f'' f'' - f'' + f'{base64.b64encode(open("images/logo-mit-tb.png", "rb").read()).decode()}" ' + f'width="150" style="border-radius: 10px;">' f'', unsafe_allow_html=True) with title_col: @@ -36,228 +47,229 @@ def auswahl_verarbeiten(): if auswahl == "Wähle eine Funktion": st.session_state.output_text = standard_output st.session_state.map_data = None - elif auswahl == "Cesarchiffre (all)": + elif "Cesarchiffre (all)" in auswahl: st.session_state.output_text = tools.cesar_all(text) st.session_state.map_data = None - elif auswahl == "BW,BWW,... ermitteln": + elif "BW,BWW,... ermitteln" in auswahl: st.session_state.output_text = tools.buchstabenwortwert(text) st.session_state.map_data = None - elif auswahl == "Buchstabenwert->Text": + elif "Buchstabenwert -> Text" in auswahl: st.session_state.output_text = tools.buchstabenwert_zu_text(text) st.session_state.map_data = None - elif auswahl == "Zeichenzählen": + elif "Zeichenzählen" in auswahl: st.session_state.output_text = tools.zeichenanzahl(text) st.session_state.map_data = None - elif auswahl == "Text rückwärts": + elif "Text rückwärts" in auswahl: st.session_state.output_text = tools.zeichenkette_reverse(text) st.session_state.map_data = None - elif auswahl == "Quersumme(n)": + elif "Quersumme(n)" in auswahl: st.session_state.output_text = tools.quersummen(text) st.session_state.map_data = None - elif auswahl == "Einschlüsse zählen": + elif "Einschlüsse zählen" in auswahl: st.session_state.output_text = tools.einschluss_count(text) st.session_state.map_data = None - elif auswahl == "ABC -> Morse": + elif "ABC -> Morse" in auswahl: st.session_state.output_text = tools.abc_to_morse(text) st.session_state.map_data = None - elif auswahl == "Morse -> ABC": + elif "Morse -> ABC" in auswahl: st.session_state.output_text = tools.morse_to_abc(text) st.session_state.map_data = None - elif auswahl == "ROT5": + elif "ROT5" in auswahl: st.session_state.output_text = tools.rot5(text) st.session_state.map_data = None - elif auswahl == "ROT13": + elif "ROT13" in auswahl: st.session_state.output_text = tools.rot13(text) st.session_state.map_data = None - elif auswahl == "ROT18": + elif "ROT18" in auswahl: st.session_state.output_text = tools.rot18(text) st.session_state.map_data = None - elif auswahl == "ROT47": + elif "ROT47" in auswahl: st.session_state.output_text = tools.rot47(text) st.session_state.map_data = None - elif auswahl == "ASCII-Text->HEX": + elif "ASCII-Text -> HEX" in auswahl: st.session_state.output_text = tools.ascii_to_hex(text) st.session_state.map_data = None - elif auswahl == "ASCII-Text->DEZ": + elif "ASCII-Text -> DEZ" in auswahl: st.session_state.output_text = tools.ascii_to_dez(text) st.session_state.map_data = None - elif auswahl == "ASCII-Text->Octal": + elif "ASCII-Text -> Octal" in auswahl: st.session_state.output_text = tools.ascii_to_octal(text) st.session_state.map_data = None - elif auswahl == "ASCII-Text->BIN (16bit)": + elif "ASCII-Text -> BIN (16bit)" in auswahl: st.session_state.output_text = tools.ascii_to_bin16(text) st.session_state.map_data = None - elif auswahl == "ASCII-Text->BIN (8bit)": + elif "ASCII-Text -> BIN (8bit)" in auswahl: st.session_state.output_text = tools.ascii_to_bin8(text) st.session_state.map_data = None - elif auswahl == "HEX->ASCII-Text": + elif "HEX -> ASCII-Text" in auswahl: st.session_state.output_text = tools.hex_to_ascii(text) st.session_state.map_data = None - elif auswahl == "DEZ->ASCII-Text": + elif "DEZ -> ASCII-Text" in auswahl: st.session_state.output_text = tools.dez_to_ascii(text) st.session_state.map_data = None - elif auswahl == "Octal->ASCII-Text": + elif "Octal -> ASCII-Text" in auswahl: st.session_state.output_text = tools.octal_to_ascii(text) st.session_state.map_data = None - elif auswahl == "BIN->ASCII-Text": + elif "BIN -> ASCII-Text" in auswahl: st.session_state.output_text = tools.bin_to_ascii(text) st.session_state.map_data = None - elif auswahl == "Zahlwortsuche-DE (0-12)": + elif "Zahlwortsuche-DE (0-12)" in auswahl: st.session_state.output_text = tools.zahlwortsuche_de(text) st.session_state.map_data = None - elif auswahl == "Zahlwortsuche-EN (0-15)": + elif "Zahlwortsuche-EN (0-15)" in auswahl: st.session_state.output_text = tools.zahlwortsuche_en(text) st.session_state.map_data = None - elif auswahl == "KENNYspeak kodieren": + elif "KENNYspeak kodieren" in auswahl: st.session_state.output_text = tools.kenny_kodieren(text) st.session_state.map_data = None - elif auswahl == "KENNYspeak dekodieren": + elif "KENNYspeak dekodieren" in auswahl: st.session_state.output_text = tools.kenny_dekodieren(text) st.session_state.map_data = None - elif auswahl == "KENNYspeak raten": + elif "KENNYspeak raten" in auswahl: st.session_state.output_text = tools.kenny_raten(text) st.session_state.map_data = None - elif auswahl == "Primz.Alpha dekodieren": + elif "Primz.Alpha dekodieren" in auswahl: st.session_state.output_text = tools.primzahlalphabet_dekodieren(text) st.session_state.map_data = None - elif auswahl == "ist (n.te) Primzahl?": + elif "ist (n.te) Primzahl?" in auswahl: st.session_state.output_text = tools.primzahlpruefen(text) st.session_state.map_data = None - elif auswahl == "zeige n.te Primzahl": + elif "zeige n.te Primzahl" in auswahl: st.session_state.output_text = tools.nte_primzahl(text) st.session_state.map_data = None - elif auswahl == "Primfaktorenzerlegung": + elif "Primfaktorenzerlegung" in auswahl: st.session_state.output_text = tools.primfaktoren(text) st.session_state.map_data = None - elif auswahl == "HEX -> DEZ,OCT,BIN": + elif "HEX -> DEZ,OCT,BIN" in auswahl: st.session_state.output_text = tools.hex_to_dez_oct_bin(text) st.session_state.map_data = None - elif auswahl == "DEZ -> HEX,OCT,BIN": + elif "DEZ -> HEX,OCT,BIN" in auswahl: st.session_state.output_text = tools.dez_to_hex_oct_bin(text) st.session_state.map_data = None - elif auswahl == "OCT -> HEX,DEZ,BIN": + elif "OCT -> HEX,DEZ,BIN" in auswahl: st.session_state.output_text = tools.oct_to_hex_dez_bin(text) st.session_state.map_data = None - elif auswahl == "BIN -> HEX,DEZ,OCT": + elif "BIN -> HEX,DEZ,OCT" in auswahl: st.session_state.output_text = tools.bin_to_hex_dez_oct(text) st.session_state.map_data = None - elif auswahl == "Text->Tomtom": + elif "Text -> Tomtom" in auswahl: st.session_state.output_text = tools.abc_to_tomtom(text) st.session_state.map_data = None - elif auswahl == "Tomtom->Text": + elif "Tomtom -> Text" in auswahl: st.session_state.output_text = tools.tomtom_to_abc(text) st.session_state.map_data = None - elif auswahl == "Text->Slash and Pipe": + elif "Text -> Slash and Pipe" in auswahl: st.session_state.output_text = tools.text_to_slashpipe(text) st.session_state.map_data = None - elif auswahl == "Slash and Pipe->Text": + elif "Slash and Pipe -> Text" in auswahl: st.session_state.output_text = tools.slashpipe_to_text(text) st.session_state.map_data = None - elif auswahl == "PSE: O.zahl<->Symbol": + elif "PSE: O.zahl <-> Symbol" in auswahl: st.session_state.output_text = tools.periodensystem(text) st.session_state.map_data = None - elif auswahl == "Nak-Nak -> Text": + elif "Nak-Nak -> Text" in auswahl: st.session_state.output_text = tools.naknak_to_text(text) st.session_state.map_data = None - elif auswahl == "Navajo -> Text": + elif "Navajo -> Text" in auswahl: st.session_state.output_text = tools.navajo_to_text(text) st.session_state.map_data = None - elif auswahl == "Kreiszahl PI": + elif "Kreiszahl PI" in auswahl: st.session_state.output_text = tools.pi_suche(text) st.session_state.map_data = None - elif auswahl == "Eulersche Zahl": + elif "Eulersche Zahl" in auswahl: st.session_state.output_text = tools.euler_suche(text) st.session_state.map_data = None - elif auswahl == "phi (goldener Schnitt)": + elif "phi (goldener Schnitt)" in auswahl: st.session_state.output_text = tools.goldener_schnitt_suche(text) st.session_state.map_data = None - elif auswahl == "Anagrammsuche-DE": + elif "Anagrammsuche-DE" in auswahl: st.session_state.output_text = tools.anagramm_suche_de(text) st.session_state.map_data = None - elif auswahl == "Anagrammsuche-EN": + elif "Anagrammsuche-EN" in auswahl: st.session_state.output_text = tools.anagramm_suche_en(text) st.session_state.map_data = None - elif auswahl == "Wortsuche-DE": + elif "Wortsuche-DE" in auswahl: st.session_state.output_text = tools.wortsuche_de(text) st.session_state.map_data = None - elif auswahl == "Wortsuche-EN": + elif "Wortsuche-EN" in auswahl: st.session_state.output_text = tools.wortsuche_en(text) st.session_state.map_data = None - elif auswahl == "Re-Morse-DE": + elif "Re-Morse-DE" in auswahl: st.session_state.output_text = tools.remorse_de(text) st.session_state.map_data = None - elif auswahl == "Re-Morse-EN": + elif "Re-Morse-EN" in auswahl: st.session_state.output_text = tools.remorse_en(text) st.session_state.map_data = None - elif auswahl == "T9-DE dekodieren": + elif "T9-DE dekodieren" in auswahl: st.session_state.output_text = tools.t9_de(text) st.session_state.map_data = None - elif auswahl == "T9-EN dekodieren": + elif "T9-EN dekodieren" in auswahl: st.session_state.output_text = tools.t9_en(text) st.session_state.map_data = None - elif auswahl == "Vigenere-Chiffre": + elif "Vigenere-Chiffre" in auswahl: st.session_state.output_text = tools.vigenere(text, additional_parameter) st.session_state.map_data = None - elif auswahl == "Wolseley-Chiffre": + elif "Wolseley-Chiffre" in auswahl: st.session_state.output_text = tools.wolseley(text, additional_parameter) st.session_state.map_data = None - elif auswahl == "Mono.-Substitution": + elif "Mono.-Substitution" in auswahl: st.session_state.output_text = tools.monoalphasubstitution(text, additional_parameter) st.session_state.map_data = None - elif auswahl == "Autokey-Chiffre": + elif "Autokey-Chiffre" in auswahl: st.session_state.output_text = tools.autokey(text, additional_parameter) st.session_state.map_data = None - elif auswahl == "Polybios kodieren": + elif "Polybios kodieren" in auswahl: st.session_state.output_text = tools.polybios_encode(text, additional_parameter) st.session_state.map_data = None - elif auswahl == "Polybios dekodieren": + elif "Polybios dekodieren" in auswahl: st.session_state.output_text = tools.polybios_decode(text, additional_parameter) st.session_state.map_data = None - elif auswahl == "Klopfcode kodieren": + elif "Klopfcode kodieren" in auswahl: st.session_state.output_text = tools.klopfcode_encode(text) st.session_state.map_data = None - elif auswahl == "Klopfcode dekodieren": + elif "Klopfcode dekodieren" in auswahl: st.session_state.output_text = tools.klopfcode_decode(text) st.session_state.map_data = None - elif auswahl == "Maptiles/Kachelkoord.": + elif "Maptiles/Kachelkoord." in auswahl: output, mapd = tools.maptiles_kachelkoordinaten(text) st.session_state.output_text = output st.session_state.map_data = mapd - elif auswahl == "Quadtree/Quadkey": + elif "Quadtree/Quadkey" in auswahl: output, mapd = tools.quadtree_koordinaten(text) st.session_state.output_text = output st.session_state.map_data = mapd - elif auswahl == "Chronogramm": + elif "Chronogramm" in auswahl: st.session_state.output_text = tools.chronogramm(text) st.session_state.map_data = None - elif auswahl == "Zahl röm.<->arabisch": + elif "Zahl röm. <-> arabisch" in auswahl: st.session_state.output_text = tools.zahlen_roemisch_arabisch_umwandeln(text) st.session_state.map_data = None - elif auswahl == "URL decode": + elif "URL decode" in auswahl: st.session_state.output_text = tools.url_decode(text) st.session_state.map_data = None - elif auswahl == "Reverse-Wherigo": - st.session_state.output_text = tools.reversewig(text) - st.session_state.map_data = None - elif auswahl == "Base64<->ASCII": + elif "Reverse-Wherigo" in auswahl: + output, mapd = tools.reversewig(text) + st.session_state.output_text = output + st.session_state.map_data = mapd + elif "Base64 <-> ASCII" in auswahl: st.session_state.output_text = tools.base64_ascii(text) st.session_state.map_data = None - elif auswahl == "Jägerzaun kodieren": + elif "Jägerzaun kodieren" in auswahl: st.session_state.output_text = tools.jaegerzaun_encrypt(text, additional_parameter) st.session_state.map_data = None - elif auswahl == "Jägerzaun dekodieren": + elif "Jägerzaun dekodieren" in auswahl: st.session_state.output_text = tools.jaegerzaun_decrypt(text, additional_parameter) st.session_state.map_data = None - elif auswahl == "ADFGX kodieren": + elif "ADFGX kodieren" in auswahl: st.session_state.output_text = tools.adfgx_kodieren(text, additional_parameter) st.session_state.map_data = None - elif auswahl == "ADFGX dekodieren": + elif "ADFGX dekodieren" in auswahl: st.session_state.output_text = tools.adfgx_dekodieren(text, additional_parameter) st.session_state.map_data = None - elif auswahl == "ADFGVX kodieren": + elif "ADFGVX kodieren" in auswahl: st.session_state.output_text = tools.adfgvx_kodieren(text, additional_parameter) st.session_state.map_data = None - elif auswahl == "ADFGVX dekodieren": + elif "ADFGVX dekodieren" in auswahl: st.session_state.output_text = tools.adfgvx_dekodieren(text, additional_parameter) st.session_state.map_data = None @@ -279,80 +291,85 @@ input_text = st.text_area('Gib deinen Text hier ein und wähle eine Funktion im # --- Sidebar: Buttons selektieren und Aktion setzen --- option = st.sidebar.radio("hidden_label", + # :color[text to be colored] -> ex.: blue[my text] + # supported colors: blue, green, orange, red, violet, gray/grey, rainbow, or primary + + # :color-badge[text in the badge] -> ex.: blue-badge[my text] + # blue, green, orange, red, violet, gray/grey, or primary options=("Wähle eine Funktion", - "Cesarchiffre (all)", - "BW,BWW,... ermitteln", - "Buchstabenwert->Text", - "Zeichenzählen", - "Text rückwärts", - "Quersumme(n)", - "Einschlüsse zählen", - "ABC -> Morse", - "Morse -> ABC", - "ROT5", - "ROT13", - "ROT18", - "ROT47", - "ASCII-Text->HEX", - "ASCII-Text->DEZ", - "ASCII-Text->Octal", - "ASCII-Text->BIN (16bit)", - "ASCII-Text->BIN (8bit)", - "HEX->ASCII-Text", - "DEZ->ASCII-Text", - "Octal->ASCII-Text", - "Zahlwortsuche-DE (0-12)", - "Zahlwortsuche-EN (0-15)", - "KENNYspeak kodieren", - "KENNYspeak dekodieren", - "KENNYspeak raten", - "Primz.Alpha dekodieren", - "ist (n.te) Primzahl?", - "zeige n.te Primzahl", - "Primfaktorenzerlegung", - "HEX -> DEZ,OCT,BIN", - "DEZ -> HEX,OCT,BIN", - "OCT -> HEX,DEZ,BIN", - "BIN -> HEX,DEZ,OCT", - "Text->Tomtom", - "Tomtom->Text", - "Text->Slash and Pipe", - "Slash and Pipe->Text", - "PSE: O.zahl<->Symbol", - "Nak-Nak -> Text", - "Navajo -> Text", - "Kreiszahl PI", - "Eulersche Zahl", - "phi (goldener Schnitt)", - "Anagrammsuche-DE", - "Anagrammsuche-EN", - "Wortsuche-DE", - "Wortsuche-EN", - "Re-Morse-DE", - "Re-Morse-EN", - "T9-DE dekodieren", - "T9-EN dekodieren", - "Vigenere-Chiffre", - "Wolseley-Chiffre", - "Mono.-Substitution", - "Autokey-Chiffre", - "Polybios kodieren", - "Polybios dekodieren", - "Klopfcode kodieren", - "Klopfcode dekodieren", - "Maptiles/Kachelkoord.", - "Quadtree/Quadkey", - "Chronogramm", - "Zahl röm.<->arabisch", - "URL decode", - "Reverse-Wherigo", - "Base64<->ASCII", - "Jägerzaun kodieren", - "Jägerzaun dekodieren", - "ADFGX kodieren", - "ADFGX dekodieren", - "ADFGVX kodieren", - "ADFGVX dekodieren", + ":orange[Cesarchiffre (all)]", + ":orange[BW,BWW,... ermitteln]", + ":blue[Buchstabenwert -> Text]", + ":orange[Zeichenzählen]", + ":orange[Text rückwärts]", + ":blue[Quersumme(n)]", + ":orange[Einschlüsse zählen]", + ":green[ABC -> Morse]", + ":green[Morse -> ABC]", + ":green[ROT5]", + ":green[ROT13]", + ":green[ROT18]", + ":green[ROT47]", + ":orange[ASCII-Text -> HEX]", + ":orange[ASCII-Text -> DEZ]", + ":orange[ASCII-Text -> Octal]", + ":orange[ASCII-Text -> BIN (16bit)]", + ":orange[ASCII-Text -> BIN (8bit)]", + ":blue[HEX -> ASCII-Text]", + ":blue[DEZ -> ASCII-Text]", + ":blue[Octal -> ASCII-Text]", + ":orange-badge[Zahlwortsuche-DE (0-12)]", + ":orange-badge[Zahlwortsuche-EN (0-15)]", + ":green[KENNYspeak kodieren]", + ":green[KENNYspeak dekodieren]", + ":green-badge[KENNYspeak raten]", + ":green[Primz.Alpha dekodieren]", + ":blue[ist (n.te) Primzahl?]", + ":blue[zeige n.te Primzahl]", + ":blue[Primfaktorenzerlegung]", + ":blue[HEX -> DEZ,OCT,BIN]", + ":blue[DEZ -> HEX,OCT,BIN]", + ":blue[OCT -> HEX,DEZ,BIN]", + ":blue[BIN -> HEX,DEZ,OCT]", + ":green[Text -> Tomtom]", + ":green[Tomtom -> Text]", + ":green[Text -> Slash and Pipe]", + ":green[Slash and Pipe -> Text]", + ":green[PSE: O.zahl <-> Symbol]", + ":green[Nak-Nak -> Text]", + ":green[Navajo -> Text]", + ":blue[Kreiszahl PI]", + ":blue[Eulersche Zahl]", + ":blue[phi (goldener Schnitt)]", + ":orange-badge[Anagrammsuche-DE]", + ":orange-badge[Anagrammsuche-EN]", + ":orange-badge[Wortsuche-DE]", + ":orange-badge[Wortsuche-EN]", + ":green-badge[Re-Morse-DE]", + ":green-badge[Re-Morse-EN]", + ":green-badge[T9-DE dekodieren]", + ":green-badge[T9-EN dekodieren]", + ":green[Vigenere-Chiffre]", + ":green[Wolseley-Chiffre]", + ":green[Mono.-Substitution]", + ":green[Autokey-Chiffre]", + ":green[Polybios kodieren]", + ":green[Polybios dekodieren]", + ":green[Klopfcode kodieren]", + ":green[Klopfcode dekodieren]", + ":violet[Maptiles/Kachelkoord.]", + ":violet[Quadtree/Quadkey]", + ":orange[Chronogramm]", + ":blue[Zahl röm. <-> arabisch]", + ":orange[URL decode]", + ":violet[Reverse-Wherigo]", + ":green[Base64 <-> ASCII]", + ":green[Jägerzaun kodieren]", + ":green[Jägerzaun dekodieren]", + ":green[ADFGX kodieren]", + ":green[ADFGX dekodieren]", + ":green[ADFGVX kodieren]", + ":green[ADFGVX dekodieren]", ), key='option', on_change=auswahl_verarbeiten, diff --git a/app/hilfetexte.py b/app/hilfetexte.py index 10cfc3d..9fee15c 100644 --- a/app/hilfetexte.py +++ b/app/hilfetexte.py @@ -517,8 +517,9 @@ reversewig = ('### Reverse Wherigo zu Koordinaten\n' ' Leider??? Ja leider denn das führt auch dazu, das es inzwischen so extrem viele dieser ' 'Reverse-Wherigos gibt wo sich die Owner anscheinend auch denken "Die spielt doch sowieso keiner ' 'mehr normal..." anders kann ich mir ganze Trails mit Reverse-Wherigos nicht erklären. Um die ' - 'Funktion zu nutzen braucht man nur die 3 Zahlen durch ein entsprechendes Trennzeichen: ' - '| , _ / ; , oder Leerzeichen eingeben und auf den Knopp klicken und bekommt Koordinaten.') + 'Funktion zu nutzen braucht man nur die 3 Zahlen getrennt durch ein entsprechendes Trennzeichen: ' + '| , _ / ; , oder Leerzeichen eingeben und auf den Knopp klicken und bekommt Koordinaten und eine ' + 'ungefähre Vorschau auf einer Karte.') base64_ascii = ('### Base64 <-> ASCII\n' 'Base64 ist ein Kodierungsverfahren, welches dazu verwendet wird um beliebige Binärdaten nur Hilfe ' diff --git a/app/images/gitea.png b/app/images/gitea.png deleted file mode 100644 index dfd2125..0000000 Binary files a/app/images/gitea.png and /dev/null differ diff --git a/app/tools.py b/app/tools.py index 27b4e7e..4bc8fd5 100644 --- a/app/tools.py +++ b/app/tools.py @@ -2209,7 +2209,7 @@ def reversewig(eingabetext): seperator = ("|,", "_", "/", ";", ",") eingabetext = eingabetext.rstrip() if eingabetext == "": - return hilfetexte.reversewig + return hilfetexte.reversewig, None else: se = "" for s in seperator: @@ -2218,26 +2218,26 @@ def reversewig(eingabetext): if se == "" and " " in eingabetext: se = " " if se == "": - return "Keine gültiges Trennzeichen (, ; / _ | oder Leerzeichen) erkannt!" + return ":red[Keine gültiges Trennzeichen (, ; / _ | oder Leerzeichen) erkannt!]" , None else: txt = eingabetext.split(se) if len(txt) == 3: - ausgabetext = "" - error = 0 for z in txt: try: int(z) except ValueError: - ausgabetext += "Bitte die Eingabezahlen überprüfen \n" - error += 1 - if error == 0: - final = helper.rwig_to_coords(txt[0], txt[1], txt[2]) - ausgabetext += "WIG: " + txt[0] + ", " + txt[1] + ", " + txt[2] + " \n" - ausgabetext += "DEC: " + str(final[0]) + " " + str(final[1]) + " \n" - ausgabetext += "DEG: " + helper.dec_to_deg(final[0], final[1]) + " \n" - return ausgabetext + return ":red[Bitte die Eingabezahlen überprüfen!]", None + la, lo = helper.rwig_to_coords(txt[0], txt[1], txt[2]) + if (not la < -85.05113 and not la > 85.05113 and not lo < -180 and not lo > 180 and + not (la == 0 and lo == 0)): + ausgabetext = f":blue[WIG:] {txt[0]}, {txt[1]}, {txt[2]} \n" + ausgabetext += f":blue[DEC:] {round(la, 5)} {round(lo, 5)} \n" + ausgabetext += f":blue[DEG:] {helper.dec_to_deg(la, lo)} \n" + return ausgabetext, pd.DataFrame({'lat': [la], 'lon': [lo]}) + else: + return f":red[Die Zahlen ergeben keine sinnvolle Koordinate!!! {la, lo}]", None else: - return "Es wurden nicht 3 Zahlen erkannt. \n" + return ":red[Es wurden nicht 3 Zahlen erkannt.]", None def base64_ascii(eingabetext): eingabetext = eingabetext.rstrip() diff --git a/readme.md b/readme.md index 02a1a33..5b8633e 100644 --- a/readme.md +++ b/readme.md @@ -4,7 +4,7 @@ Dies ist die Umsetzung der [Desktop-App Mysteryhelfer](https://mysteryhelfer.teb Für die Umsetzung kommt das Python-Framework [Streamlit](https://streamlit.io/) zum Einsatz, durch welches es mir möglich war, dieselben Funktionen zu implementieren wie sie für die Desktop-App genutzt werden. (Für die Funktionen war hier primär nur die Ausgabe anzupassen.) -Der einfachst Weg, um die App lokal laufen zu lassen, ist mit Docker, wobei ich hier mal 3 Möglichkeiten aufzeige: +Der einfachst Weg, um die App lokal laufen zu lassen, ist mit Docker, wobei ich hier mal 3 Möglichkeiten aufzeigen (_das vorgebaute Image ist als Multi-Arch-Image für linux/amd64,linux/arm64 gebaut und sollte somit z.B. auch auf Mac's und neueren Raspberry's mit 64 bit Betriebssystem laufen_): 1. mit vorgebautem Image: - `docker run --rm -d -p 8501:8501 gitea.tebarius.duckdns.org/tebarius/mysteryhelfer`