File size: 3,162 Bytes
369a349 743de20 c754616 743de20 8400f85 743de20 c754616 743de20 c754616 743de20 c754616 743de20 c754616 743de20 c754616 743de20 c754616 743de20 c754616 743de20 c754616 743de20 c754616 743de20 c754616 4ee3288 39bf55d |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 |
import streamlit as st
import nltk
from nltk.corpus import words
st.title("Word Game Solver")
@st.cache # cache the download process
def download():
nltk.download('words')
download()
[a,b,c,d,e,f,g] = st.columns(7)
with a:
first_letter = st.text_input(label="1st",value = 'a')
with b:
second_letter = st.text_input(label="2nd", value = 'e')
with c:
third_letter = st.text_input(label="3rd", value = 'i')
with d:
fourth_letter = st.text_input(label="4th", value = 'o')
with e:
fifth_letter = st.text_input(label="5th", value = 'u')
with f:
sixth_letter = st.text_input(label="6th", value = '')
with g:
seventh_letter = st.text_input(label="7th", value = '')
clue2 = first_letter+second_letter
clue3 = first_letter+second_letter+third_letter
clue4 = first_letter+second_letter+third_letter+fourth_letter
clue5 = first_letter+second_letter+third_letter+fourth_letter+fifth_letter
clue6 = first_letter+second_letter+third_letter+fourth_letter+fifth_letter+sixth_letter
clue7 = first_letter+second_letter+third_letter+fourth_letter+fifth_letter+sixth_letter+seventh_letter
st.markdown("### clue")
st.write(clue2)
st.write(clue3)
st.write(clue4)
st.write(clue5)
st.write(clue6)
st.write(clue7)
exclusions = st.text_input(label="exclusions")
clue_result2 = []
clue_result3 = []
clue_result4 = []
clue_result5 = []
clue_result6 = []
clue_result7 = []
two_letters = [word for word in words.words() if len(word)==2 ]
three_letters = [word for word in words.words() if len(word)==3 ]
four_letters = [word for word in words.words() if len(word)==4 ]
five_letters = [word for word in words.words() if len(word)==5 ]
six_letters = [word for word in words.words() if len(word)==6 ]
seven_letters = [word for word in words.words() if len(word)==7 ]
for word in two_letters:
if all(c in word for c in clue2) and not any(c in word for c in exclusions):
clue_result2.append(word)
for word in three_letters:
if all(c in word for c in clue3) and not any(c in word for c in exclusions):
clue_result3.append(word)
for word in four_letters:
if all(c in word for c in clue4) and not any(c in word for c in exclusions):
clue_result4.append(word)
for word in five_letters:
if all(c in word for c in clue5) and not any(c in word for c in exclusions):
clue_result5.append(word)
for word in six_letters:
if all(c in word for c in clue6) and not any(c in word for c in exclusions):
clue_result6.append(word)
for word in seven_letters:
if all(c in word for c in clue7) and not any(c in word for c in exclusions):
clue_result7.append(word)
st.write(clue_result2)
st.write(clue_result3)
st.write(clue_result4)
st.write(clue_result5)
st.write(clue_result6)
st.write(clue_result7)
import requests
from bs4 import BeautifulSoup as bs
import lxml.etree as xml
import lxml
def define(word):
url = f'https://www.dictionary.com/browse/{word}?s=t'
web_page = bs(requests.get(url, {}).text, "lxml")
meanings = web_page.find_all('div', attrs={'class': 'css-1ghs5zt e1q3nk1v2'})
for meaning in meanings:
st.write('* '+ meaning.text)
st.write(meanings[0].text)
for word in clue_result7:
define(word) |