61 lines
2 KiB
Python
61 lines
2 KiB
Python
import random
|
|
|
|
kbloc = [[x for x in "1234567890-="],
|
|
[x for x in "qwertyuiop[]"],
|
|
[x for x in "asdfghjkl:;'"],
|
|
[x for x in "zxcvbnm,.>/?"]]
|
|
kbdict = {}
|
|
for (i, l) in enumerate(kbloc):
|
|
for (j, k) in enumerate(l):
|
|
kbdict[k] = (i, j)
|
|
|
|
sounddict = {"a": "e", "b": "d", "c": "k", "d": "g", "e": "eh",
|
|
"f": "ph", "g": "j", "h": "h", "i": "ai", "j": "ge",
|
|
"k": "c", "l": "ll", "m": "n", "n": "m", "o": "oa",
|
|
"p": "b", "q": "kw", "r": "ar", "s": "ss", "t": "d",
|
|
"u": "you", "v": "w", "w": "wn", "x": "cks", "y": "uy", "z": "s"}
|
|
|
|
|
|
def mispeller(word):
|
|
if len(word) <= 6:
|
|
num = 1
|
|
else:
|
|
num = random.choice([1,2])
|
|
wordseq = list(range(0, len(word)))
|
|
random.shuffle(wordseq)
|
|
letters = wordseq[0:num]
|
|
def mistype(string, i):
|
|
l = string[i]
|
|
if l not in kbdict:
|
|
return string
|
|
lpos = kbdict[l]
|
|
newpos = lpos
|
|
while newpos == lpos:
|
|
newpos = ((lpos[0] + random.choice([-1, 0, 1])) % len(kbloc),
|
|
(lpos[1] + random.choice([-1,0,1])) % len(kbloc[0]))
|
|
string = string[0:i]+kbloc[newpos[0]][newpos[1]]+string[i+1:]
|
|
return string
|
|
def transpose(string, i):
|
|
j = (i + random.choice([-1,1])) % len(string)
|
|
l = [c for c in string]
|
|
l[i], l[j] = l[j], l[i]
|
|
return "".join(l)
|
|
def randomletter(string, i):
|
|
string = string[0:i+1]+random.choice("abcdefghijklmnopqrstuvwxyz")+string[i+1:]
|
|
return string
|
|
def randomreplace(string, i):
|
|
string = string[0:i]+random.choice("abcdefghijklmnopqrstuvwxyz")+string[i+1:]
|
|
return string
|
|
def soundalike(string, i):
|
|
try:
|
|
c = sounddict[string[i]]
|
|
except:
|
|
return string
|
|
string = string[0:i]+c+string[i+1:]
|
|
return string
|
|
func = random.choice([mistype, transpose, randomletter, randomreplace,
|
|
soundalike])
|
|
for i in letters:
|
|
word = func(word, i)
|
|
return word
|