-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathseed.py
81 lines (62 loc) · 2.23 KB
/
seed.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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
"""Utility file to seed vitamins database from NIH data in seed/data"""
from sqlalchemy import func
from model import User, Vitamin, User_Vitamin, connect_to_db, db
from server import app
import csv
import requests
import json
def load_labels():
"""Load vitamin labels from lstProducts.csv into database"""
with open("seed_data/lstProducts.csv") as vit:
reader = csv.reader(vit)
# row_num = 1 #use for testing?
for row in reader:
vitamin = Vitamin(label_id=row[0],
brand_name=row[1],
product_name=row[2],
net_contents=row[3],
net_content_unit=row[4],
serving_size_quantity=row[5],
serving_size_unit=row[6],
product_type=row[7],
supplement_form=row[8],
dietary_claims=row[9],
target_groups=row[10],
database=row[11],
tracking_history=row[12])
db.session.add(vitamin)
db.session.commit()
def update_labels_directions():
"""Add directions field to Vitamin db"""
labels = Vitamin.query.all()
label_1 = labels[:1000]
label_2 = labels[1000:5000]
label_3 = labels[5000:10000]
label_4 = labels[10000:15000]
label_5 = labels[15000:20000]
label_6 = labels[20000:25000]
label_7 = labels[25000:30000]
label_8 = labels[30000:35000]
label_9 = labels[35000:45000]
label_10 = labels[45000:55000]
label_11 = labels[55000:65000]
label_12 = labels[65000:75000]
label_13 = labels[75000:85000]
label_14 = labels[85000:]
for product in label_14:
vit_id = product.label_id
r = requests.get("http://dsld.nlm.nih.gov/dsld/api/label/" + vit_id)
vitamin = r.json()
try:
directions = vitamin["Suggested_Use"]
except KeyError:
print(vitamin)
import pdb; pdb.set_trace()
if directions:
product.use = directions
db.session.commit()
if __name__ == "__main__":
connect_to_db(app)
db.create_all()
# load_labels()
update_labels_directions()