


Résoudre les énigmes des cookies de mots : une aventure Python
Jouer à des jeux est un moyen de détendre le cerveau du stress de la journée, ou peut-être simplement de prendre des pauses au travail. Parfois cependant, les jeux peuvent être stressants en eux-mêmes, et je pense que c'est le cas de "Word Cookies", un jeu de réflexion amusant dans lequel vous recevez un ensemble de lettres brouillées et êtes chargé de résoudre les mots qu'ils contiennent. 🎜>
Maintenant, comment puis-je utiliser Python pour résoudre les parieurs brouillés. J'avais besoin d'un moyen de vérifier les mots dans les lettres brouillées et j'ai divisé la mise en œuvre en étapes simples.
Plan:
- Obtenez un dictionnaire de mots pour vérifier les lettres brouillées.
- Créez un CSV contenant uniquement des mots de n lettres, dans ce cas j'ai créé un CSV contenant des mots de 3 lettres à des mots de 7 lettres
- Vérifiez si un mot du csv a toutes ses lettres contenues dans les lettres brouillées
- Enregistrez-le dans une liste de son propre nombre de mots, par exemple, si un mot est « âge », alors il sera enregistré dans une liste de mots de 3 lettres, et ainsi de suite.
- Afficher le résultat
Tout d'abord, j'ai cherché en ligne et j'ai trouvé un dictionnaire que je pouvais télécharger au format CSV et je l'ai divisé en fichiers CSV séparés contenant chaque lettre. Voici à quoi cela ressemble :
Voici à quoi cela ressemble :
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.")
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)
Nous prenons le dossier de sortie du code précédent et l'utilisons comme dossier d'entrée dans le code de solution réel ci-dessus. La beauté de cette solution réside dans la simplicité de la fonction 'is_word_in_string'. Nous n'avons pas besoin de vérifier si les lettres individuelles sont contenues dans les mots brouillés, car cela nécessitera une logique supplémentaire écrite pour les lettres qui apparaissent plus d'une fois.
Il suffit de vérifier si pour chaque lettre d'un mot du dictionnaire, elle apparaît inférieure ou égale au nombre de fois qu'elle apparaît dans les mots brouillés, et boum, nous pouvons confirmer si chaque lettre du mot du dictionnaire existe réellement dans la lettre brouillée.
Voyons le code en action :
Hourra ! Et maintenant, j'ai un moyen d'avancer lorsque je suis coincé. Il ne s’agit pas seulement de toujours tromper le système, ce n’est pas amusant, mais quand j’en ai vraiment besoin, ce solveur s’avère pratique. Je peux également obtenir autant de mots supplémentaires que possible afin de pouvoir remplir ce pot et obtenir des ressources géniales.
Et voilà. Python est un langage polyvalent pour automatiser les tâches rapides. Vous pouvez l'utiliser simplement dans vos activités quotidiennes comme celle-ci, ou pour des tâches de travail complexes et même des travaux beaucoup plus avancés tels que l'apprentissage automatique. Trouvez un projet Python sur lequel travailler aujourd'hui. Bravo.
Hé, je m'appelle Ifedolapo, je suis développeur frontend et programmeur python (je conçois aussi d'ailleurs). Vous pouvez en savoir plus sur moi sur le site Web Portfolio
Merci d'avoir parcouru ce post.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Comment éviter d'être détecté lors de l'utilisation de FiddlereVerywhere pour les lectures d'homme dans le milieu lorsque vous utilisez FiddlereVerywhere ...

Fastapi ...

Utilisation de Python dans Linux Terminal ...

Comment enseigner les bases de la programmation novice en informatique dans les 10 heures? Si vous n'avez que 10 heures pour enseigner à l'informatique novice des connaissances en programmation, que choisissez-vous d'enseigner ...

À propos de Pythonasyncio ...

Comprendre la stratégie anti-rampe d'investissement.com, Beaucoup de gens essaient souvent de ramper les données d'actualités sur Investing.com (https://cn.investing.com/news/latest-news) ...

Chargement du fichier de cornichon dans Python 3.6 Erreur d'environnement: modulenotFounonError: NomoduLenamed ...

Discussion sur les raisons pour lesquelles les fichiers de pipelines ne peuvent pas être écrits lors de l'utilisation de robots scapisnels lors de l'apprentissage et de l'utilisation de Crawlers scapides pour un stockage de données persistant, vous pouvez rencontrer des fichiers de pipeline ...
