Skip to content

linuxsoftware/words

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

23 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

WS/WORDS
========

This is my implementation of a cryptogram solver, It will only work with 
simple-substitution ciphers (aka aristocrats).

CREDIT
======
Cryptograms and how to solve them was explained to me by Simon Jansen.  This code is based
on that.

COMPATABILITY
=============
Pure standard python, no extra packages needed.  Tested with Python 3.7.  Other Python
versions > 3.4 may work.

WSBUILD
=======
First you need to build a catalog file from a word list.  Sometimes a short word list of
common words is useful, sometimes a long list like /usr/share/dict/words works better.

Here's some sources of words that I have found:
 - https://gist.github.com/deekayen/4148741
 - https://github.com/dwyl/english-words
 - https://github.com/sujithps/Dictionary
 - /usr/share/dict/words

Build a catalog from your word list using the wsbuild command.

e.g.  ./wsbuild.py words.txt catalog.db

words.txt is the word list and catalog.db is the name for the catalog to create.

WSSOLVE
=======
Now you can run the solver passing it the catalog you just created.

e.g.  ./wssolve.py catalog.db

It will prompt you to enter the cryptogram.  Punctuation can be entered and will be
ignored, except that contractions with ' are accepted as valid words.

Next it will prompt for any known letters.  These can be entered in one of two possible
formats:

1. Letter assignments: e.g. M=J NBI=THE etc

2. Valid text matching letter for letter with the cryptogram above.  Use spaces for the
   letters that are not known.

Wssolve will try and solve the cryptogram and print out words that match.

Even if wssolve does not completely solve the cryptogram it may reduce the possibilities
down to where the solution is easy to spot by the semantics and grammar.

EXAMPLE

$ ./wssolve.py words.db 
Enter the cryptogram:    AXSBZ OYXM EXGGZEE CO FKWP OYX KWS PY BNQZ XI NR YMSZM PY BZP NP
Enter any known letters: W=A
Matching 38 possible words at go 3
Matching 38 possible words at go 4
Filtered 0 with words in go 0
axsbz oyxm exggzee co fkwp oyx kws py bnqz xi nr ymszm py bzp np
Cipher axsbzoymegcfkwpnqir->[bfjn]udgeyorsc[bmn][fkptw][hl]a[nt]i[bv][kmnpv][fnqt]

_udge your success _y __a_ you _ad _o gi_e u_ i_ order _o ge_ i_
budge your success by flan you had no gibe uk if order no gen in 
fudge              my flat     lad to give um in       to get it 
judge              ny khan                 un iq                 
nudge                 plan                 up it                 
                      than                 uv                    
                      what 

BUGS/TO DO
==========
Automatically try different catalogs
Drop words and backtrack when matching or filtering gives no solution
Run multiple attempts starting on different words
Option to brute force cipher
More tests

COPYRIGHT
=========
David Moore 2021.
Licensed under the GPL.  See LICENSE.

Have fun.

About

cryptogram solver

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages