本文整理匯總了Python中mixpanel.Mixpanel.request方法的典型用法代碼示例。如果您正苦於以下問題:Python Mixpanel.request方法的具體用法?Python Mixpanel.request怎麽用?Python Mixpanel.request使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類mixpanel.Mixpanel
的用法示例。
在下文中一共展示了Mixpanel.request方法的10個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: get_event_data
# 需要導入模塊: from mixpanel import Mixpanel [as 別名]
# 或者: from mixpanel.Mixpanel import request [as 別名]
def get_event_data(events, unit=DEFAULT_UNIT, interval=DEFAULT_INTERVAL):
"""Retrieve event data for a list of events"""
MIXPANEL_API_KEY = os.environ["MIXPANEL_API_KEY"]
MIXPANEL_API_SECRET = os.environ["MIXPANEL_API_SECRET"]
client = Mixpanel(api_key=MIXPANEL_API_KEY, api_secret=MIXPANEL_API_SECRET)
response = client.request('events', 'general', {
'event' : events,
'unit' : unit,
'interval' : interval
})
return response['data']['values']
示例2: MixpanelTest
# 需要導入模塊: from mixpanel import Mixpanel [as 別名]
# 或者: from mixpanel.Mixpanel import request [as 別名]
class MixpanelTest(object):
def __init__(self):
with open('etc/mp.yml', 'r') as f:
mp = yaml.load(f)
self.api = Mixpanel(
api_key=mp['api_key'],
api_secret=mp['api_secret']
)
def request(self, funnel_id, seg_property, from_date):
data = self.api.request(['funnels'], {
'funnel_id': funnel_id,
'on': 'properties["%s"]' % seg_property,
'from_date': from_date,
'to_date': datetime.date.today().isoformat(),
'interval': 60
})['data']
return data[from_date]
def test(self, data, control, variations):
update = {}
buckets = [control] + variations
for bucket in buckets:
total = data[bucket][0]['count']
successes = data[bucket][1]['count']
update[bucket] = (successes, total - successes)
test = Trials(buckets)
test.update(update)
dominances = test.evaluate('dominance', control=control)
lifts = test.evaluate('expected lift', control=control)
intervals = test.evaluate('lift CI', control=control, level=95)
for variation in variations:
print('Variation {name}:'.format(name=variation))
s, t = update[variation]
print('* Successes: {0}, Total: {1}, Percent: {2:2.3f}%'.format(s, t, 100*float(s)/t))
print('* E[lift] = {value:.2%}'.format(value=lifts[variation]))
print('* P({lower:.2%} < lift < {upper:.2%}) = 95%'.format(lower=intervals[variation][0], upper=intervals[variation][2]))
print('* P({name} > {control}) = {value:.2%}'.format(name=variation, control=control, value=dominances[variation]))
print
示例3: mixpanel_main
# 需要導入模塊: from mixpanel import Mixpanel [as 別名]
# 或者: from mixpanel.Mixpanel import request [as 別名]
def mixpanel_main():
api_client = Mixpanel(mp['APIKEY'], mp['APISECRET'])
data = api_client.request(['events'], {
'event' : ['create_feature', 'signup', 'add_member'],
'unit' : 'week',
'interval' : 2,
'type': 'general'
})
date = data['data']['series'][0]
print "Metrics for the week\n"
print "Mixpanel\n"
global mp_signups
global mp_members
global mp_features
mp_signups = data['data']['values']['signup'][date]
mp_members = data['data']['values']['add_member'][date]
mp_features = data['data']['values']['create_feature'][date]
print "Signups: " + str(mp_signups)
print "Members added: " + str(mp_members)
print "Created first feature: " + str(mp_features)
示例4: getShownSubModal
# 需要導入模塊: from mixpanel import Mixpanel [as 別名]
# 或者: from mixpanel.Mixpanel import request [as 別名]
def getShownSubModal(api_key, api_secret, startDate, endDate):
# print 'Requesting Mixpanel data'
api = Mixpanel(
api_key = api_key,
api_secret = api_secret
)
data = api.request(['export'], {
'event' : ['Show subscription modal',],
'from_date' : startDate,
'to_date' : endDate
})
uniques = set()
# biggestDate = 0
lines = data.split('\n')
# print "Received %d entries" % len(lines)
for line in lines:
try:
if len(line) is 0: continue
event = json.loads(line)
properties = event['properties']
if not event['event'] in ['Show subscription modal']:
print 'Unexpected event ' + event['event']
break
# print 'Processing', event['event'], properties['time'], properties['dateCreated']
if 'distinct_id' in properties and not properties['distinct_id'] in uniques:
uniques.add(properties['distinct_id'])
# if int(properties['time']) > biggestDate:
# biggestDate = int(properties['time'])
except:
print "Unexpected error:", sys.exc_info()[0]
print line
break
# print 'Biggest date:', datetime.utcfromtimestamp(int(properties['time']))
return len(uniques)
示例5: printPriceConversionRates
# 需要導入模塊: from mixpanel import Mixpanel [as 別名]
# 或者: from mixpanel.Mixpanel import request [as 別名]
def printPriceConversionRates(api_key, api_secret, startDate, endDate):
# dateCreated is in UTC
# Dec 8th subscribe copy A/B test added
# 599 - 1st HoC 599 sale started: Dec 9 6:23am PST
# 999 - 1st HoC 599 sale ended: Dec 10 4:34pm PST
# 1499 - sub price test starts: Dec 10 5:00pm PST
# Only for dateCreated >= 5pm PST
# 399 - 2nd HoC 399 sale started: Dec 11 7:21pm PST
# 999 - 2nd HoC sale ended: Dec 13 9:30am PST
# UTC is +8 hrs
api = Mixpanel(
api_key = api_key,
api_secret = api_secret
)
print 'Requesting Mixpanel data'
# data = api.request(['events'], {
# 'event' : ['Finished subscription purchase',],
# 'unit' : 'hour',
# 'interval' : 24,
# 'type': 'general'
# })
# data = api.request(['funnels', 'list'], {})
data = api.request(['export'], {
'event' : ['Show subscription modal', 'Finished subscription purchase',],
# 'event' : ['Finished subscription purchase',],
# 'event' : ['Show subscription modal',],
'from_date' : startDate,
'to_date' : endDate
})
prices = {
'399': {
'start': datetime(2014, 12, 12, 3, 21),
'end': datetime(2014, 12, 13, 17, 30)
},
'599': {
'start': datetime(2014, 12, 9, 14, 23),
'end': datetime(2014, 12, 11, 0, 34)
},
'999': {
'start': datetime(2014, 9, 1),
'end': datetime(2014, 12, 9, 14, 23),
'start2': datetime(2014, 12, 11, 0, 34),
'end2': datetime(2014, 12, 12, 3, 21),
'start3': datetime(2014, 12, 13, 17, 30)
},
'1499': {
'start': datetime(2014, 12, 11, 1),
'end': datetime(2014, 12, 12, 3, 21)
}
}
# id vs distinct_id ?
def addEvent(price, event, id):
if not event in price:
price[event] = {}
price[event][id] = True
elif not id in price[event]:
price[event][id] = True
def getPriceStr(eventDateStr, userDateStr):
priceStr = '999'
eventCreated = datetime.utcfromtimestamp(int(eventDateStr))
# Put events in buckets based on creation times
if eventCreated >= prices['599']['start'] and eventCreated < prices['599']['end']:
priceStr = '599'
elif eventCreated >= prices['999']['start2'] and eventCreated < prices['999']['end2']:
# In 999/1499 zone
# Create a datetime from: 2014-12-11T12:37:59
userCreated = datetime(int(userDateStr[0:4]), int(userDateStr[5:7]), int(userDateStr[8:10]), int(userDateStr[11:13]), int(userDateStr[14:16]), int(userDateStr[17:19]))
if userCreated >= prices['1499']['start']:
priceStr = '1499'
elif eventCreated >= prices['399']['start'] and eventCreated < prices['399']['end']:
priceStr = '399'
return priceStr
lines = data.split('\n')
print "Received %d entries" % len(lines)
for line in lines:
try:
if len(line) is 0: continue
event = json.loads(line)
properties = event['properties']
if not event['event'] in ['Show subscription modal', 'Finished subscription purchase']:
print 'Unexpected event ' + event['event']
break
# print 'Processing', event['event'], properties['time'], properties['dateCreated']
if 'dateCreated' in properties and 'time' in properties and 'distinct_id' in properties:
# NOTE: mixpanel conversions don't account for refunds
# NOTE: So we have an extra 1499 hit for [email protected] / 5488ee8a600bc8b206771ba3
if properties['distinct_id'] == '5488ee8a600bc8b206771ba3':
# ch_155tz8KaReE7xLUdQpsa9aqe, cus_5GQqAosNHuRQCQ
# print 'Skipping [email protected] / 5488ee8a600bc8b206771ba3'
# print event['event'], properties['distinct_id']
continue
# if properties['distinct_id'] == '54790dacfd5b8f550584aaf3':
#.........這裏部分代碼省略.........
示例6: len
# 需要導入模塊: from mixpanel import Mixpanel [as 別名]
# 或者: from mixpanel.Mixpanel import request [as 別名]
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-14'
endDate = '2014-12-21'
print("Requesting data for {0} to {1}".format(startDate, endDate))
data = api.request(['export'], {
'event' : ['Show subscription modal', 'Started subscription purchase', 'Finished subscription purchase'],
'from_date' : startDate,
'to_date' : endDate
})
userProgressionGroupA = {}
userProgressionGroupB = {}
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']
properties = eventData['properties']
if not eventName in ['Show subscription modal', 'Started subscription purchase', 'Finished subscription purchase']:
示例7: Mixpanel
# 需要導入模塊: from mixpanel import Mixpanel [as 別名]
# 或者: from mixpanel.Mixpanel import request [as 別名]
else:
api_key = sys.argv[1]
api_secret = sys.argv[2]
api = Mixpanel(
api_key = api_key,
api_secret = api_secret
)
startDate = '2015-01-15'
startDate = '2014-11-25'
endDate = '2015-02-11'
print("Requesting data for {0} to {1}".format(startDate, endDate))
data = api.request(['export'], {
'event' : ['Started purchase', 'Finished gem purchase'],
'from_date' : startDate,
'to_date' : endDate
})
userProgressionGroupA = {}
userProgressionGroupB = {}
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']
properties = eventData['properties']
if not eventName in ['Started purchase', 'Finished gem purchase']:
示例8: Mixpanel
# 需要導入模塊: from mixpanel import Mixpanel [as 別名]
# 或者: from mixpanel.Mixpanel import request [as 別名]
api = Mixpanel(
api_key = api_key,
api_secret = api_secret
)
startDate = '2015-01-01'
endDate = '2015-01-26'
startEvent = eventFunnel[0]
endEvent = eventFunnel[-1]
print("Requesting data for {0} to {1}".format(startDate, endDate))
data = api.request(['export'], {
# 'where': '"539c630f30a67c3b05d98d95" == properties["id"]',
# 'where': "('539c630f30a67c3b05d98d95' == properties['id'] or '539c630f30a67c3b05d98d95' == properties['distinct_id'])",
'event': eventFunnel,
'from_date': startDate,
'to_date': endDate
})
weirdUserIDs = []
eventUsers = {}
levelEventUserDayMap = {}
levelUserEventDayMap = {}
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)
示例9: print
# 需要導入模塊: from mixpanel import Mixpanel [as 別名]
# 或者: from mixpanel.Mixpanel import request [as 別名]
api_secret = api_secret
)
# startDate = '2015-01-11'
# endDate = '2015-01-17'
startDate = '2015-01-23'
endDate = '2015-01-23'
# endDate = '2015-01-28'
startEvent = eventFunnel[0]
endEvent = eventFunnel[-1]
print("Requesting data for {0} to {1}".format(startDate, endDate))
data = api.request(['export'], {
'event' : eventFunnel,
'from_date' : startDate,
'to_date' : endDate
})
# Map ordering: level, user, event, day
userDataMap = {}
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 eventFunnel:
print 'Unexpected event ' + eventName
示例10: MixSwissKnife
# 需要導入模塊: from mixpanel import Mixpanel [as 別名]
# 或者: from mixpanel.Mixpanel import request [as 別名]
class MixSwissKnife(object):
def __init__(self, api_key, api_secret, period_threshold = 1, usage_threshold = 1, where = "true", period = "week"):
self.api_key = api_key
self.api_secret = api_secret
self.api = Mixpanel(self.api_key, self.api_secret)
#self.users = []
self.daily_threshold = period_threshold
self.usage_threshold = usage_threshold
self.where = where
self.period = period
self.user_data = {}
pass
def track_users_feature(self, feature, from_date, to_date):
data = self.api.request(['segmentation'], {
'event' : feature,
'on': 'properties["username"]',
'where': self.where,
'from_date': from_date,
'to_date': to_date,
'unit' : self.period,
'type': 'general',
'limit': 1000
})
print data
user_data = data['data']['values']
for user in user_data:
days = 0
for d in user_data[user]:
if user_data[user][d] > self.daily_threshold:
days = days + 1
total_days = len(user_data[user])
usage = float(days * 100) / total_days
#print user, ' --> ', "%0.2f" % usage , '%'
#if user not in self.users:
# self.users.append(user)
if usage > 0:
if not self.user_data.has_key(user):
self.user_data[user] = {}
self.user_data[user][feature] = usage
'''
How many users use a feature?
'''
def analyze_feature(self, feature):
users = 0
frequency = []
for user in self.users():
user_info = self.user_data[user]
if user_info.has_key(feature) and user_info[feature] > self.usage_threshold:
users = users + 1
frequency.append(user_info[feature])
usage = float(users) * 100 / len(self.users())
#print users, 'out of', len(self.users())
#print frequency
#print self.mean(frequency), '[', max(frequency), ',', min(frequency), ']'
#lets calculate frequency
return usage, self.mean(frequency)
def num_users(self):
return len(self.user_data.keys())
def users(self):
return self.user_data.keys()
def mean(self, l):
return float(sum(l))/len(l) if len(l) > 0 else float('nan')
def median(self, l):
sorts = sorted(l)
length = len(sorts)
if not length % 2:
return (sorts[length / 2] + sorts[length / 2 - 1]) / 2.0
return sorts[length / 2]