我正在尝试按照purchase_state
以下步骤从谷歌播放中提取:
import base64
import requests
import smtplib
from collections import OrderedDict
import mysql.connector
from mysql.connector import errorcode
......
- 查询数据库,从我的表中返回数千行
purchase_id
字段- 检查 db 中的每一行,并提取 purchase_id,然后查询所有这些行的 google play。例如,如果我上一步的结果是 1000,则 1000 次是查询 google(刷新令牌 + 查询)。
purchase status
除了从 mysql 查询中获取的其他一些字段之外,将 google play 中的新字段添加到新字典中。- 最后一步是对我的 dic 进行循环,然后准备所需的报告
编辑后:
def build_dic_from_db(data,access_token):
dic = {}
for row in data:
product_id = row['product_id']
purchase_id = row['purchase_id']
status = check_purchase_status(access_token, product_id,purchase_id)
cnt = 1
if row['user'] not in dic:
dic[row['user']] = {'id':row['user_id'],'country': row['country_name'],'reg_ts': row['user_registration_timestamp'],'last_active_ts': row['user_last_active_action_timestamp'],
'total_credits': row['user_credits'],'total_call_sec_this_month': row['outgoing_call_seconds_this_month'],'user_status':row['user_status'],'mobile':row['user_mobile_phone_number_num'],'plus':row['user_assigned_msisdn_num'],
row['product_id']:{'tAttemp': cnt,'tCancel': status}}
else:
if row['product_id'] not in dic[row['user']]:
dic[row['user']][row['product_id']] = {'tAttemp': cnt,'tCancel':status}
else:
dic[row['user']][row['product_id']]['tCancel'] += status
dic[row['user']][row['product_id']]['tAttemp'] += cnt
return dic
问题是我的代码运行缓慢〜总执行时间:448.7483880519867,我想知道是否有改进我的脚本。有什么建议吗?