-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathimport.py
74 lines (62 loc) · 2.07 KB
/
import.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
import os
import csv,requests
from sqlalchemy import create_engine
from sqlalchemy.orm import scoped_session, sessionmaker
if not os.getenv("DATABASE_URL"):
raise RuntimeError("DATABASE_URL is not set")
engine = create_engine(os.getenv("DATABASE_URL"))
db = scoped_session(sessionmaker(bind=engine))
def create_tables():
with open('SCHEMA.sql','r',newline='') as f:
commands = [i.strip() for i in f.read().split(';')]
for command in commands:
print(command)
db.execute(command)
db.commit()
def get_books_data():
with open('books.csv','r',newline='') as rf:
csvfile = csv.reader(rf)
next(csvfile)
while csvfile:
frame = {}
try:
for i in range(500):
row = next(csvfile)
frame[row[0]] = row
except StopIteration :
break
isbns = ','.join(frame)
res = requests.get("https://www.goodreads.com/book/review_counts.json", params={"key": "6ptJdBeyhCL2l0nTBXeLg", "isbns": isbns})
data = res.json()['books']
for book in data:
yield [ *frame[book['isbn']], book['work_reviews_count'], book['average_rating']]
def insert_books():
cnt = 0
items = get_books_data()
for item in items:
isbn, title, author, year, reviews_count, average_rating = item
db.execute(
'INSERT INTO books (isbn, title, author, year, reviews_count, average_rating)'
' VALUES (:isbn, :title, :author, :year, :reviews_count, :average_rating)',
{
'isbn':isbn,
'title':title,
'author':author,
'year':year,
'reviews_count':reviews_count,
'average_rating':average_rating
}
)
cnt+=1
if cnt%100==0:
db.commit()
db.commit()
def CommandDC():
db.execute( """ SELECT * FROM reviews """)
CommandDC()
command = 0
if command :
create_tables()
insert_books()
db.close()
engine.dispose()