Spiele sind eine Möglichkeit, das Gehirn vom Stress des Tages zu entspannen oder einfach eine Pause von der Arbeit einzulegen. Manchmal können Spiele jedoch schon allein eine Belastung sein, und das ist meiner Meinung nach der Fall bei „Word Cookies“, einem unterhaltsamen Puzzlespiel, bei dem man einen Satz verwürfelter Buchstaben erhält und die Aufgabe hat, die darin enthaltenen Wörter zu finden.
Je weiter ich im Spiel vorankam, desto schwieriger wurde es, es zu lösen, da ich kaum oder gar keine Ressourcen hatte, um zu helfen, und ich blieb mehrmals stecken. Aber Moment mal, ich programmiere in Python, warum finde ich also keinen Ausweg? Hier kommt die Python-Sprache zum Vorschein.
Wie verwende ich nun Python, um die verschlüsselten Probleme zu lösen? Ich brauchte eine Möglichkeit, Wörter in den verschlüsselten Buchstaben zu überprüfen, und habe die Implementierung in einfache Schritte unterteilt.
Zuerst habe ich online gesucht und ein Wörterbuch gefunden, das ich im CSV-Format herunterladen und in separate CSV-Dateien mit jedem Buchstaben aufteilen konnte. So sieht es aus:
Als nächstes habe ich mir einen Python-Code besorgt, um die CSVs von A bis Z zu durchsuchen und die 3-Buchstaben-Wörter herauszusuchen und Wörter mit Leerzeichen und anderen unbrauchbaren Formaten wegzulassen. Dies wurde gleichzeitig bei Wörtern mit 4, 5, 6 und 7 Buchstaben durchgeführt.
So sieht es aus:
import os import csv import re import pandas as pd # Define folder paths input_folder = 'C:\Users\Zenbook\Desktop\Word lists in csv' output_folder = 'C:\Users\Zenbook\Desktop\Word list output' # Function to find words of specific lengths in text def find_words_of_length(text, length): words = re.findall(r'\b\w+\b', text) return [word for word in words if len(word) == length] # Initialize dictionaries to store words of each length words_by_length = {3: set(), 4: set(), 5: set(), 6: set(), 7: set()} # Loop through all CSV files in the input folder for filename in os.listdir(input_folder): if filename.endswith('.csv'): filepath = os.path.join(input_folder, filename) # Read each CSV file with a fallback encoding with open(filepath, 'r', encoding='ISO-8859-1') as file: reader = csv.reader(file) for row in reader: # Loop through each cell in the row for cell in row: for length in words_by_length.keys(): words = find_words_of_length(cell, length) words_by_length[length].update(words) # Save words of each length to separate CSV files for length, words in words_by_length.items(): output_file = os.path.join(output_folder, f'{length}_letters.csv') with open(output_file, 'w', newline='', encoding='utf-8') as file: writer = csv.writer(file) for word in sorted(words): # Sort words for neatness writer.writerow([word]) print("Words have been saved to separate CSV files based on their length.")
Hier ist das Ergebnis im von mir angegebenen Ausgabeordner:
Jetzt muss ich bei diesem Ausgabeordner nur noch die darin enthaltenen Wörter überprüfen, um zu sehen, ob sie in den verschlüsselten Buchstaben enthalten sind. Hier ist der Code, der das tut:
import csv # Define the string to check against check_string = 'langaur' # Define the folder path for CSV files input_folder = 'C:\Users\Zenbook\Desktop\Word list output' # Function to check if all letters in word can be found in check_string def is_word_in_string(word, check_string): # Check if each letter in the word is in the string for letter in word: if word.count(letter) > check_string.count(letter): return False return True # Check words for 3, 4, 5, 6 and 7-letter CSVs for length in [3, 4, 5, 6, 7]: input_file = f'{input_folder}/{length}_letters.csv' print(f"\nLength {length}:") with open(input_file, 'r', encoding='utf-8') as file: reader = csv.reader(file) found_words = [] for row in reader: word = row[0].strip() # Remove any extra whitespace if is_word_in_string(word, check_string): found_words.append(word) # Print all found words for the given length for i in found_words: print(i)
Wir nehmen den Ausgabeordner aus dem vorherigen Code und verwenden ihn als Eingabeordner im tatsächlichen Lösungscode oben. Das Schöne an dieser Lösung liegt in der Einfachheit der Funktion „is_word_in_string“. Wir müssen nicht prüfen, ob die einzelnen Buchstaben in den verschlüsselten Wörtern enthalten sind, da für Buchstaben, die mehr als einmal vorkommen, eine zusätzliche Logik geschrieben wird.
Wir müssen nur prüfen, ob jeder Buchstabe in einem Wörterbuchwort seltener oder genauso oft vorkommt wie in den verschlüsselten Wörtern, und schon können wir bestätigen, ob jeder Buchstabe des Wörterbuchworts tatsächlich existiert im verschlüsselten Brief.
Hurra! Und jetzt habe ich eine Möglichkeit, weiterzukommen, wenn ich nicht weiterkomme. Es geht nicht immer nur darum, das System zu betrügen, das macht keinen Spaß, aber wenn ich es wirklich brauche, ist dieser Löser praktisch. Ich kann auch so viele zusätzliche Wörter wie möglich bekommen, damit ich das Glas füllen und tolle Ressourcen erhalten kann.
Und da ist es. Python ist eine vielseitige Sprache, um schnelle Dinge zu automatisieren. Sie können es einfach bei Ihren alltäglichen Aktivitäten wie dieser oder für komplexe Arbeitsaufgaben und sogar weitaus fortgeschrittenere Arbeiten wie maschinelles Lernen verwenden. Finden Sie noch heute ein Python-Projekt, an dem Sie arbeiten können. Prost.
Hey, mein Name Ifedolapo, ich bin Frontend-Entwickler und Python-Programmierer (ich entwerfe übrigens auch). Mehr über mich erfahren Sie auf der Portfolio-Website
Vielen Dank, dass Sie diesen Beitrag gelesen haben.
Das obige ist der detaillierte Inhalt vonWortplätzchen-Rätsel lösen: Ein Python-Abenteuer. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!