-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathmain.py
More file actions
50 lines (39 loc) · 1.22 KB
/
main.py
File metadata and controls
50 lines (39 loc) · 1.22 KB
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
def main():
book_path = "books/frankenstein.txt"
text = get_book_text(book_path)
num_words = word_count(text)
#print(f"{num_words} words found in the document")
chars_dict = get_chars_dict(text)
chars_sorted_list = chars_dict_to_sorted_list(chars_dict)
print(f"--- Begin report of {book_path} ---")
print(f"{num_words} words found in the document")
print()
for item in chars_sorted_list:
if not item["char"].isalpha():
continue
print(f"The '{item['char']}' character was found {item['num']} times")
print("--- End report ---")
def word_count(text):
words = text.split()
return len(words)
def sort_on(d):
return d["num"]
def get_book_text(path):
with open(path) as f:
return f.read()
def get_chars_dict(text):
chars = {}
for c in text:
lowered = c.lower()
if lowered in chars:
chars[lowered] += 1
else:
chars[lowered] = 1
return chars
def chars_dict_to_sorted_list(num_chars_dict):
sorted_list = []
for ch in num_chars_dict:
sorted_list.append({"char": ch, "num": num_chars_dict[ch]})
sorted_list.sort(reverse=True, key=sort_on)
return sorted_list
main()