mirror of
https://github.com/codeninjasllc/codecombat.git
synced 2024-11-24 08:08:15 -05:00
d89b0d90e3
Fixing incorrect dropped counts. Restricting start/finish level events to unique users. Does not fix campaign editor level view analytics.
82 lines
2.9 KiB
Python
82 lines
2.9 KiB
Python
# Calculate level completion rates via mixpanel export API
|
|
|
|
# TODO: unique users
|
|
# TODO: align output
|
|
# TODO: order output
|
|
|
|
import sys
|
|
from mixpanel import Mixpanel
|
|
|
|
try:
|
|
import json
|
|
except ImportError:
|
|
import simplejson as json
|
|
|
|
# NOTE: mixpanel dates are by day and inclusive
|
|
# E.g. '2014-12-08' is any date that day, up to 2014-12-09 12am
|
|
|
|
if __name__ == '__main__':
|
|
if not len(sys.argv) is 3:
|
|
print "Script format: <script> <api_key> <api_secret>"
|
|
else:
|
|
api_key = sys.argv[1]
|
|
api_secret = sys.argv[2]
|
|
api = Mixpanel(
|
|
api_key = api_key,
|
|
api_secret = api_secret
|
|
)
|
|
|
|
startDate = '2014-12-31'
|
|
endDate = '2015-01-05'
|
|
print("Requesting data for {0} to {1}".format(startDate, endDate))
|
|
data = api.request(['export'], {
|
|
'event' : ['Started Level', 'Saw Victory'],
|
|
'from_date' : startDate,
|
|
'to_date' : endDate
|
|
})
|
|
|
|
levelRates = {}
|
|
lines = data.split('\n')
|
|
print "Received %d entries" % len(lines)
|
|
for line in lines:
|
|
try:
|
|
if len(line) is 0: continue
|
|
eventData = json.loads(line)
|
|
eventName = eventData['event']
|
|
if not eventName in ['Started Level', 'Saw Victory']:
|
|
print 'Unexpected event ' + eventName
|
|
break
|
|
properties = eventData['properties']
|
|
if 'levelID' in properties:
|
|
levelID = properties['levelID']
|
|
elif 'level' in properties:
|
|
levelID = properties['level'].lower().replace(' ', '-')
|
|
else:
|
|
print("Unkonwn levelID for", eventName)
|
|
print(properties)
|
|
break
|
|
if not levelID in levelRates:
|
|
levelRates[levelID] = {'started': 0, 'finished': 0}
|
|
if eventName == 'Started Level':
|
|
levelRates[levelID]['started'] += 1
|
|
elif eventName == 'Saw Victory':
|
|
levelRates[levelID]['finished'] += 1
|
|
else:
|
|
print("Unknown event name", eventName)
|
|
print(eventData)
|
|
break
|
|
except:
|
|
print "Unexpected error:", sys.exc_info()[0]
|
|
print line
|
|
break
|
|
|
|
# print(levelRates)
|
|
for levelID in levelRates:
|
|
started = levelRates[levelID]['started']
|
|
finished = levelRates[levelID]['finished']
|
|
# if not levelID == 'endangered-burl':
|
|
# continue
|
|
if started > 0:
|
|
print("{0}\t{1}\t{2}\t{3}%".format(levelID, started, finished, float(finished) / started * 100))
|
|
else:
|
|
print("{0}\t{1}\t{2}".format(levelID, started, finished))
|