forked from kiranvodrahalli/cos521
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtweet_parser.py
36 lines (32 loc) · 1.34 KB
/
tweet_parser.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
import sys
import json
import codecs
def parse_tweet_file(tweet_file):
'''Writes a file of
tweet_id,timestamp,hashtag
for the tweets in the input json file.'''
outfile = tweet_file.replace('.json', '.out')
out_f = codecs.open(outfile, 'w', encoding='utf-8')
with open(tweet_file) as f:
for line in f:
tweet = json.loads(line.strip())
if ('id' in tweet and 'created_at' in tweet and
'text' in tweet and 'lang' in tweet and
tweet['lang'] == 'en'):
if '#' in tweet['text']:
tweet_id = unicode(tweet['id'])
tweet_timestamp = tweet['created_at']
tag_tokens = tweet['text'].strip().split('#')[1:]
tags = [token.split()[0].rstrip('?:!.,;') for token in tag_tokens if token.split()]
for tag in tags:
out_f.write(','.join([tweet_id, tweet_timestamp, tag+'\n']))
if __name__=='__main__':
if len(sys.argv) != 2:
print 'Usage: python tweet_parser.py <DATA_DIR>'
sys.exit()
import os
for root, dirs, files in os.walk(sys.argv[1]):
for filename in files:
if filename.endswith('.json'):
print os.path.join(root, filename)
parse_tweet_file(os.path.join(root, filename))