40 Commits

Author SHA1 Message Date
b84fc555c9 Amélioration de la mise en page avec Markdown du fichier README.md 2026-02-26 23:17:48 +01:00
f03a10466b Amélioration de la mise en page avec Markdown du fichier README.md 2026-02-26 23:17:12 +01:00
ff87d27ef5 Licence MIT 2026-02-26 23:11:57 +01:00
6f1ab9dbe8 Merge remote-tracking branch 'brunus/main' 2026-02-26 23:06:15 +01:00
Brunus
7f54aece7b Upload New File 2026-02-26 08:54:42 +00:00
Brunus
c6fb7ebbae Delete fr_10letters.json 2026-02-26 08:54:01 +00:00
Brunus
0e6ce6e249 Edit README.md 2026-02-26 08:53:44 +00:00
Brunus
465bfb78f7 Edit README.md 2026-02-26 08:43:28 +00:00
Brunus
1644254162 Nouveau dictionnaire de mots en 10 lettres 2026-02-26 08:39:53 +00:00
Brunus
48dbc04d0c correction de mots avec espace en dernière lettre 2022-01-26 11:22:23 +01:00
Brunus
d92925ed07 Update README.md 2022-01-26 08:41:06 +00:00
Brunus
78af8000e8 Update README.md 2022-01-26 08:37:28 +00:00
01a6b4ca6b bugfix : ne pas utiliser pattern et firsttry ensemble 2022-01-25 15:46:05 +01:00
443d5facd5 Création d'un nouveau dictionnaire fr à base d'autres dictionnaires 2022-01-25 15:46:05 +01:00
79540341d4 Réécriture du dictionnaire Sutom (gain de place) 2022-01-25 15:46:04 +01:00
53e6d2f2ac Mise à jour de l'aide pour la fonction pattern 2022-01-25 15:46:04 +01:00
07bc289c03 Amélioration de "resolv_pattern()" 2022-01-25 15:46:04 +01:00
09f1f8f65d Travaille en majuscule 2022-01-25 15:46:04 +01:00
86d2fcee4e "not in" 2022-01-25 15:46:04 +01:00
91de6012dc Optimisation de "resolv_bl()" 2022-01-25 15:46:04 +01:00
41b7681e04 Optimisation de "noDouble()" 2022-01-25 15:46:04 +01:00
8bf0ec59df Optimisations 2022-01-25 15:46:04 +01:00
7a163e8f4b Nettoyage 2022-01-25 10:42:54 +01:00
afbf6e87c5 Fonction "Pattern" 2022-01-25 10:42:54 +01:00
d5c4b4b233 Fonction "Bad Letters" 2022-01-25 10:42:54 +01:00
4513f059f0 Fonction "Know Letters" 2022-01-25 10:42:54 +01:00
d3f994ea92 Nettoyage 2022-01-25 10:42:54 +01:00
1eca719fd8 Fonction "First Try" 2022-01-25 10:42:54 +01:00
ecff9a87bd Réorganisation du code 2022-01-25 10:42:54 +01:00
ba37f6c03e Ajout de l'option "no double" 2022-01-25 10:42:54 +01:00
98d4966a5b Préparation pour l'affichage des résultats 2022-01-25 10:42:54 +01:00
f879e01397 Simplification de l'argument du nombre de lettre 2022-01-25 10:42:54 +01:00
b19ad51639 Fonction pour charger le dictionnaire et début de mise en forme du programme 2022-01-25 10:42:54 +01:00
6183c8a4f5 Fonction pour la longueur du mot 2022-01-25 10:42:54 +01:00
9144e942c9 Fonction pour la première lettre 2022-01-25 10:42:54 +01:00
d80816a0b1 Simplification du argparse 2022-01-25 10:42:54 +01:00
826df9c336 Comme l'on a des arguments obligatoires, pas de besoin de vérifier s'il y en a. 2022-01-25 10:42:54 +01:00
cd3da5357a Ouvre le dictionnaire avec un 'with statement' 2022-01-25 10:42:54 +01:00
d62ace44a4 import os : pas besoin 2022-01-25 10:42:54 +01:00
ecc47f1008 Python3 2022-01-25 10:42:54 +01:00
4 changed files with 5174 additions and 29 deletions

7
LICENCE.md Normal file
View File

@@ -0,0 +1,7 @@
Copyright 2026 AntoineVe & Brunus
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

123
README.md
View File

@@ -1,40 +1,107 @@
# wgamesolv # wgamesolv
Words Games Solver. > **Words Games Solver** — Script d'aide à la résolution des jeux de mots style Wordle, SUTOM, mots-croisés, Scrabble...
Script d'aide à la résolution des jeux de mots style Wordle, SUTOM, mots-croisés, Scrabble... > On a fait ça pour s'amuser, pas spécialement pour tricher aux jeux de mots.
On a fait ça pour s'amuser, pas spécialement pour tricher aux jeux de mots.
Auteurs : AntoineVe et Brunus.
Courageux testeur des 1ères versions et précieux apporteur d'idées: DarKou.
Licence : MIT
Utilisation : wgamesolv.py -d dictionnaire.json -nb 7 (autres options) - **Auteurs :** AntoineVe, Brunus
- **Courageux testeur des 1ères versions et précieux apporteur d'idées :** DarKou
- **Licence :** MIT
-d, --dictionary : dictionnaire à utiliser ---
ex : -d fr_Fc.json
Trois dictionnaires ont été fusionnés pour n'en faire qu'un : Wordle, SUTOM et l'officiel du Scrabble
-fl, --firstLetter : première lettre du mot > [!WARNING]
ex : -fl C > Le dictionnaire `fr_FR.json` n'est plus à jour. Il doit soit être mis à jour soit remplacé par des dictionnaires de mots en x lettres, comme le nouveau `fr_A_10letters.json` (mots de 10 lettres commençant par la lettre A) qui lui est à jour (le 26 fév. 2026).
Cette option est intéressante que l'on connaisse ou non la première lettre, il faut en choisir une pour limiter la liste de mots possibles.
-nb, --nbLetters : nombre de lettres qui composent le mot ---
ex : -nb 7
-ft, --firstTry : optimise le premier essai en sortant les mots de -nb lettres, commençant par -fl lettre, ne contenant aucune lettre en plusieurs occurence et contenant -ft voyelles. ## Utilisation
ex : -ft 4
Cette option peut être utilisée pour le tout premier essai, pour optimiser les chances d'avoir des lettres validées.
Cette option est ensuite inutile ou contre-productive pour les essais suivants et ne peut pas être utilisée avec la pattern.
-nd, --noDoubleLetters : filtre les mots composé d'une seule occurence de chaque lettre. ```
wgamesolv.py -d dictionnaire.json -nb 7 [autres options]
```
-kl, --knownLetters : lettres déjà validées ## Options
ex : -kl AEP
-bl, --badLetters : lettres déjà invalidées ### `-d`, `--dictionary` — dictionnaire à utiliser
ex : -bl ZTOR
-p, --pattern : lettres validées et bien placées, lettres connues et mal placées, séparée par des '.' pour les lettres non validées ```
Les lettres en caps sont les lettres connues et bien placées, les lettres en minuscules sont les lettres connues mais mal placées -d fr_FR.json
ex : -p L.uI... (le mots était LUCIOLE) ```
Exemple complet : wgamesolv.py -d fr_FR.json -nb 7 -fl L -p L.uI... -kl U -bl AMNR Trois dictionnaires ont été fusionnés pour n'en faire qu'un : Wordle, SUTOM et l'officiel du Scrabble.
---
### `-nb`, `--nbLetters` — nombre de lettres du mot
```
-nb 7
```
---
### `-fl`, `--firstLetter` — première lettre du mot
```
-fl C
```
Cette option est intéressante que l'on connaisse ou non la première lettre : il faut en choisir une pour limiter la liste de mots possibles.
---
### `-ft`, `--firstTry` — optimisation du premier essai
```
-ft 4
```
Optimise le premier essai en sortant les mots de `-nb` lettres, commençant par `-fl`, ne contenant aucune lettre en plusieurs occurrences et contenant `-ft` voyelles.
> Cette option peut être utilisée pour le tout premier essai, pour optimiser les chances d'avoir des lettres validées. Elle est ensuite inutile ou contre-productive pour les essais suivants et **ne peut pas être utilisée avec la pattern**.
---
### `-nd`, `--noDoubleLetters` — sans lettres doublées
Filtre les mots composés d'une seule occurrence de chaque lettre.
---
### `-kl`, `--knownLetters` — lettres déjà validées
```
-kl AEP
```
---
### `-bl`, `--badLetters` — lettres déjà invalidées
```
-bl ZTOR
```
---
### `-p`, `--pattern` — lettres placées et mal placées
```
-p L.uI...
```
| Casse | Signification |
|-------|---------------|
| Majuscule | Lettre connue et **bien placée** |
| minuscule | Lettre connue mais **mal placée** |
| `.` | Position non validée |
*Exemple : `-p L.uI...` pour le mot LUCIOLE*
---
## Exemple complet
```
wgamesolv.py -d fr_FR.json -nb 7 -fl L -p L.uI... -kl U -bl AMNR
```

5071
fr_A_10letters.json Normal file

File diff suppressed because it is too large Load Diff

File diff suppressed because one or more lines are too long