-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathRedditScraper.py
94 lines (70 loc) · 2.96 KB
/
RedditScraper.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
82
83
84
85
86
87
88
89
90
91
92
93
import os
from typing import List
from dotenv import load_dotenv
import praw
from pandas import DataFrame
import pandas as pd
from openpyxl import load_workbook
# Load API Keys
load_dotenv()
client_id = os.getenv('CLIENT_ID')
client_secret = os.getenv('CLIENT_SECRET')
user_agent = os.getenv('APP_NAME')
username = os.getenv('REDDIT_USER_NAME')
password = os.getenv('REDDIT_PASSWORD')
reddit = praw.Reddit(client_id = client_id,
client_secret = client_secret,
username = username,
user_agent = user_agent,
password = password)
# Retrieve Posts Function
reddit_message_dict = []
def retrieve_posts(subred_input, result_input, limit_input, subred_type):
subred = reddit.subreddit(subred_input)
if subred_type == "new":
subred_test = subred.new(limit=limit_input)
if subred_type == "top":
subred_test = subred.top(limit=limit_input)
if subred_type == "hot":
subred_test = subred.hot(limit=limit_input)
for i in subred_test:
if i.is_self and i.url not in reddit_message_dict:
pulled_reddit_message = {'url': i.url,
'subreddit': subred_input,
'title': i.title,
'author_name': i.author,
'created': i.created, # in Unix time
'score': i.score,
'upvote_ratio': i.upvote_ratio,
'content': i.selftext,
'result': result_input}
reddit_message_dict.append(pulled_reddit_message)
# Write to excel file
DB_columns = ['url', 'subreddit', 'title', 'author_name', 'created', 'score', 'upvote_ratio', 'content', 'result']
def Write_xlsx(file_name, reddit_dict):
df = DataFrame(reddit_dict, columns=DB_columns)
df.to_excel(file_name, index=False)
def Append_xlsx(file_name, reddit_dict):
final_dict = []
# check if post is already in DB
df = pd.ExcelFile(file_name).parse('Sheet1')
for x in reddit_dict:
if x['url'] in df['url'].to_list():
continue
final_dict.append(x)
print("-------------------->>> RES")
df_new = pd.DataFrame(final_dict, columns=DB_columns)
writer = pd.ExcelWriter(file_name, engine='openpyxl')
# try to open an existing workbook
writer.book = load_workbook(file_name)
# copy existing sheets
writer.sheets = dict((ws.title, ws) for ws in writer.book.worksheets)
# read existing file
reader = pd.read_excel(file_name)
# write out the new sheet
df_new.to_excel(writer, index=False, header=False, startrow=len(reader) + 1)
writer.close()
# Retrieve Happy/Sad posts
# output, limit, typ ("new", "hot", "top")
retrieve_posts("CongratsLikeImFive", 0, 100, "hot")
Append_xlsx('Depression_Reddit_Database_Final.xlsx', reddit_message_dict)