-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathtest-bayes.py
66 lines (54 loc) · 1.81 KB
/
test-bayes.py
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
from sklearn.feature_extraction.text import CountVectorizer, TfidfTransformer, TfidfVectorizer
from sklearn.model_selection import train_test_split
from sklearn.naive_bayes import GaussianNB, MultinomialNB
from sklearn.utils import Bunch
from budgery.db import crud, models
from budgery.db.connection import connect, session
from starlette.config import Config
def all_transaction_descriptions(db):
all_transactions = crud.transaction_list(db)
return [t.description for t in all_transactions]
def categorized_transaction_bunch(db) -> Bunch:
transactions = crud.transaction_list_with_category(db)
data = []
target = []
target_names = []
categories_to_id = {}
index = 0
for transaction in transactions:
category_id = categories_to_id.get(transaction.category)
if category_id is None:
categories_to_id[transaction.category] = index
category_id = index
target_names.append(transaction.category)
index += 1
data.append(transaction.description)
target.append(category_id)
bunch = Bunch(
data=data,
target=target,
target_names=target_names,
)
return bunch
def main() -> None:
config = Config("env")
engine = connect(config)
db = session(engine)
all_descriptions = all_transaction_descriptions(db)
bunch = categorized_transaction_bunch(db)
tfidf_vectorizer = TfidfVectorizer()
train_tfidf = tfidf_vectorizer.fit_transform(bunch.data)
clf = MultinomialNB().fit(train_tfidf, bunch.target)
print("trained")
uncategorized_transactions = crud.transaction_list(
db=db,
category="None",
limit=10,
)
to_categorize = [t.description for t in uncategorized_transactions][:20]
new_tfidf = tfidf_vectorizer.transform(to_categorize)
predicted = clf.predict(new_tfidf)
for doc, category in zip(to_categorize, predicted):
print(f"{doc} => {bunch.target_names[category]}")
if __name__ == "__main__":
main()