forked from justmarkham/DAT4
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path03_getting_data.py
119 lines (96 loc) · 4.21 KB
/
03_getting_data.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
import requests # how python goes onto the internet!
import tweepy # python wrapper for twitter api
import json # javascript object notation
import time # timey wimey stuff
import re # regex
from BeautifulSoup import BeautifulSoup # a python HTML parser (version 3)
from bs4 import BeautifulSoup # (version 4)
# this is my own personal twitter api information
# if you could be so kind as to sign up yourself on both twitter and mashape that'd be great :)
# It's FREEEEEEE
api_key = 'IWIQwPUREMNuQHgZii351TRSq'
api_secret = 'i1E4MSvMEifjeBTp1hxxAT3RTOTFHdRJhRTWyBBXjWWqPgW2RN'
access_token = '532821167-m3HQCKb8iKjWpyB2u0KoeIuJTsJNvxSapqGA0wdd'
access_secret = '0HsqZ3lXcWvhmPWiSvrz8t8aMHcdSnvARbH6OPYy9Dcm7'
mashape_key = '0CLvblsJOxmshWkaep4szo9CILOMp1PM3hhjsnDi4k8g8ME14o'
'''
Example of NO API, we will use requests and BeautifulSoup
'''
def getStockPrice(symbol): # symbol could be aapl, nflx, ge, etc
r = requests.get('http://finance.google.com/finance?q='+symbol) # the url of the google finance page goes in here
b = BeautifulSoup(r.text) # create a beautifulsoup object
# b = BeautifulSoup(r.text, 'html.parser') # try this line instead if you have problems
#print b.prettify() # will print the html nicely
re_tag = re.compile("ref_\d+_l") #this tag finds the tag with the price in it!!!!
span_tag = b.find('span', attrs={'id': re_tag})
# use find to return THE ONE AND ONLY span tags with an id that matches our regex
# use findAll to find all matches
quote = span_tag.text # get the text of the tag
return quote
print getStockPrice('aapl')
'''
Example of API but NO WRAPPER
there is no wrapper for this API, so I use requests, a python module for accessing web content
to access the information
in a sense, this is a wrapper that I just wrote for the Natural Language Processing API!
'''
def get_sentiment(phrase):
response = requests.post("https://japerk-text-processing.p.mashape.com/sentiment/",
headers={
"X-Mashape-Key": mashape_key,
"Content-Type": "application/x-www-form-urlencoded"
},
data={
"language": "english",
"text": phrase
}
)
return json.loads(response.text)
print get_sentiment("I really love this song!")
'''
Example of API WITH WRAPPER
tweepy is the python wrapper for twitter data
'''
def getTweetsOnTag(tag):
# Documentation is your friend!
auth = tweepy.OAuthHandler(api_key, api_secret)
auth.set_access_token(access_token, access_secret)
api = tweepy.API(auth) # returns a tweepy authorization handler object
for tweet in api.search(q=tag):
# other arguments exist, CHECK DOCUMENTATION
# print tweet # is a BIG dictionary!!
print tweet.created_at, tweet.text
# http://docs.tweepy.org/en/v3.1.0/
getTweetsOnTag("starbucks")
'''
THE BELOW CODE IS OPTIONAl
It creates a stream of a given tag!
'''
# This is the listener, resposible for receiving data
# I will not be covering this in class
class StdOutListener(tweepy.StreamListener):
def on_data(self, data):
# Twitter returns data in JSON format - we need to decode it first
decoded = json.loads(data)
#print decoded
time_ = time.strftime('%Y-%m-%d %H:%M:%S', time.localtime(int(decoded['timestamp_ms']) / 1000))
handle = decoded['user']['screen_name']
tweet_text = decoded['text'].encode('ascii', 'ignore')
num_followers = int(decoded['user']['followers_count'])
# Also, we convert UTF-8 to ASCII ignoring all bad characters sent by users
print '@%s at %s: %s with %d followers' % (handle, time_, tweet_text, num_followers)
print 'sentiment: '+get_sentiment(tweet_text)['label']
print ''
return True
def on_error(self, status):
print status
def begin_live_feed(tags_to_follow):
print "beginning live feed...."
l = StdOutListener()
auth = tweepy.OAuthHandler(api_key, api_secret)
auth.set_access_token(access_token, access_secret)
stream = tweepy.Stream(auth, l)
stream.filter(track=tags_to_follow)
begin_live_feed(['@ga', '@ga_ny', '@ga_dc'])
# this is an example use, if you create a list of words and phrases,
# a live stream of tweets about them will show up