-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmain.py
138 lines (118 loc) · 4.8 KB
/
main.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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
import logging
import logging.config
import os
import pickle
import sys
import time
from multiprocessing import Process, Lock
from crawler.twitter_covid19_api_crawler import TweetCOVID19APICrawler
from crawler.twitter_covid19_api_v2_crawler import TweetCOVID19APIV2Crawler
from crawler.twitter_filter_api_crawler import TweetFilterAPICrawler
from crawler.twitter_id_mode_crawler import TweetIDModeCrawler
from crawler.twitter_search_api_crawler import TweetSearchAPICrawler
# from dumper.twitter_dumper import TweetDumper
from extractor.twitter_extractor import TweetExtractor
from paths import TWITTER_TEXT_CACHE, LOG_DIR, BACKUP_DIR, CACHE_DIR
from utilities.cacheset import CacheSet
# from utilities.connection import Connection
try:
cache: CacheSet[int] = pickle.load(open(TWITTER_TEXT_CACHE, 'rb+'))
except:
cache = CacheSet()
def _fetch_id_from_db():
"""a generator which generates 100 id list at a time"""
result = list()
# for id, in Connection.sql_execute(
# f"SELECT id FROM records WHERE create_at IS NULL and deleted IS NOT TRUE ORDER BY id DESC"):
# if id not in cache:
# cache.add(id)
# result.append(id)
# if len(result) == 100:
# yield result
# result.clear()
# pickle.dump(cache, open(TWITTER_TEXT_CACHE, 'wb+'))
yield result
def start(mode):
# tweet_dumper = TweetDumper()
tweet_extractor = TweetExtractor()
if mode == "filter_mode":
tweet_filter_api_crawler = TweetFilterAPICrawler()
while True:
keywords = read_keywords()
ids = tweet_filter_api_crawler.crawl(keywords, batch_number=100)
# tweet_dumper.insert(ids, id_mode=True)
time.sleep(10)
elif mode == "search_mode":
tweet_search_api_crawler = TweetSearchAPICrawler()
while True:
keywords = read_keywords()
ids = tweet_search_api_crawler.crawl(keywords, batch_number=100)
# tweet_dumper.insert(ids, id_mode=True)
elif mode == "id_mode":
tweet_id_mode_crawler = TweetIDModeCrawler()
while True:
try:
for ids in _fetch_id_from_db():
status = tweet_id_mode_crawler.crawl(ids)
logging.info(ids)
tweets = tweet_extractor.extract(status)
ids_with_text = {t['id'] for t in tweets}
ids_no_text = set(ids) - ids_with_text
logging.info(ids_no_text)
tweet_extractor.export(status, file_name="coronavirus")
# tweet_dumper.insert(tweets)
# tweet_dumper.delete(ids_no_text)
time.sleep(5)
except:
pass
finally:
time.sleep(5)
elif mode == 'covid19_mode':
threads = list()
lock = Lock()
# for mode in ['id_mode', 'search_mode', 'filter_mode']:
def thread_function(partition):
try:
tweets = list()
for tweet in TweetCOVID19APICrawler().crawl(partition):
tweets.append(tweet)
if len(tweets) == 100:
lock.acquire()
tweet_extractor.export(tweets, file_name="coronavirus")
lock.release()
tweets.clear()
except:
lock.acquire()
exit(1)
for i in range(1, 5):
thread = Process(target=thread_function, args=(i,))
threads.append(thread)
thread.start()
for index, thread in enumerate(threads):
thread.join()
logging.info("Main : thread %d done", index)
elif mode == 'covid19_v2_mode':
TweetCOVID19APIV2Crawler(tweet_extractor).crawl()
def read_keywords():
keywords = set()
with open("keywords.txt", 'r') as file:
for line in file:
keyword = line.strip().lower()
if keyword:
keywords.add(keyword)
logging.info(f"LOADING keywords={keywords}")
return list(keywords)
if __name__ == "__main__":
format = '[%(asctime)s] [%(levelname)s] [%(threadName)s] [%(module)s] [%(funcName)s]: %(message)s'
handler_name = 'main.log'
current_time = time.strftime('%m%d%Y_%H-%M-%S_', time.localtime(time.time()))
# logging.basicConfig(format=format, level=logging.ERROR, filename=os.path.join(LOG_DIR, current_time + handler_name),
# datefmt="%H:%M:%S")
# logging.getLogger().addHandler(logging.StreamHandler())
if not os.path.exists(CACHE_DIR):
os.makedirs(CACHE_DIR)
if not os.path.exists(BACKUP_DIR):
os.makedirs(BACKUP_DIR)
logging.info('Crawler Starting...')
# for mode in ['id_mode', 'search_mode', 'filter_mode']:
start(sys.argv[1])