Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/isida/4.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authordiSabler <dissy@ya.ru>2014-06-15 10:32:19 +0400
committerdiSabler <dissy@ya.ru>2014-06-15 10:32:19 +0400
commit3bb8c02cc713cf42e1bb497d7277d998afd951ae (patch)
treed5d9c869a9d898ab49207e7807f49fdf60b74c56
parent9c2b5019224e4283534092e3c757cecd088f4964 (diff)
upd: wot.py - updated formulas, some fixes
-rw-r--r--plugins/wot.py162
1 files changed, 85 insertions, 77 deletions
diff --git a/plugins/wot.py b/plugins/wot.py
index 341ebe5..0868e93 100644
--- a/plugins/wot.py
+++ b/plugins/wot.py
@@ -28,7 +28,7 @@ APP_ID = '171745d21f7f98fd8878771da1000a31';
clantags = re.compile('(\(.*?\))|(\[.*?\])')
def get_tanks_data():
- data = urllib.urlopen('%s/2.0/encyclopedia/tanks/?application_id=%s&fields=level,name_i18n,name' % (API_ADDR, APP_ID))
+ data = urllib.urlopen('%s/wot/encyclopedia/tanks/?application_id=%s&fields=level,name_i18n,name' % (API_ADDR, APP_ID))
d = json.load(data)
res = {}
for i in d['data']:
@@ -59,28 +59,36 @@ def wot(type, jid, nick, text):
else:
name, tank = text[0], text[1].lower()
try:
- data = load_page('%s/2.0/account/list/?application_id=%s&search=%s&fields=id&limit=1' % (API_ADDR, APP_ID, name))
+ data = load_page('%s/2.0/account/list/?application_id=%s&search=%s&fields=account_id&limit=1' % (API_ADDR, APP_ID, name))
v = json.loads(data)
- player_id = str(v['data'][0]['id'])
-
- data = load_page('%s/2.0/account/tanks/?application_id=%s&account_id=%s&fields=statistics,tank_id,mark_of_mastery' % (API_ADDR, APP_ID, player_id))
+ player_id = str(v['data'][0]['account_id'])
+
+ data = load_page('%s/2.0/tanks/stats/?application_id=%s&account_id=%s' % (API_ADDR, APP_ID, player_id))
vdata = json.loads(data)
-
- data = load_page('%s/2.0/account/info/?application_id=%s&account_id=%s&fields=clan,nickname,statistics' % (API_ADDR, APP_ID, player_id))
+
+ data = load_page('%s/2.0/account/tanks/?application_id=%s&account_id=%s&fields=mark_of_mastery,tank_id' % (API_ADDR, APP_ID, player_id))
+ vdata_old = json.loads(data)
+ vdata_old = dict([[i['tank_id'], i['mark_of_mastery']] for i in vdata_old['data'][player_id]])
+
+ data = load_page('%s/2.0/account/info/?application_id=%s&account_id=%s&fields=nickname,statistics,global_rating' % (API_ADDR, APP_ID, player_id))
pdata = json.loads(data)
stat = pdata['data'][player_id]['statistics']
-
- if pdata['data'][player_id]['clan']:
- clan_id = str(pdata['data'][player_id]['clan']['clan_id'])
+
+
+ data = load_page('%s/wot/clan/membersinfo/?application_id=%s&member_id=%s' % (API_ADDR, APP_ID, player_id))
+ claninfo = json.loads(data)
+
+ if claninfo['data'][player_id]:
+ clan_id = str(claninfo['data'][player_id]['clan_id'])
data = load_page('%s/2.0/clan/info//?application_id=%s&clan_id=%s&fields=abbreviation' % (API_ADDR, APP_ID, clan_id))
cdata = json.loads(data)
cname = cdata['data'][clan_id]['abbreviation']
except:
pdata = {'status': ''}
-
+
if pdata['status'] == 'ok' and pdata['data'][player_id]:
- wotname = pdata['data'][player_id]['nickname'] + ('[%s]' % cname if pdata['data'][player_id]['clan'] else '')
-
+ wotname = pdata['data'][player_id]['nickname'] + ('[%s]' % cname if claninfo['data'][player_id] else '')
+
if tank:
if len(tank) == 1:
msg = L('Use more characters in the name of the tank','%s/%s'%(jid,nick))
@@ -88,11 +96,11 @@ def wot(type, jid, nick, text):
try:
msg = '%s:' % wotname
tids = [tid for tid in tanks_data if tank in tanks_data[tid]['name'].lower() or tank in tanks_data[tid]['name_i18n'].lower()]
-
+
for t in vdata['data'][player_id]:
if str(t['tank_id']) in tids:
- tank_win = t['statistics']['wins']
- tank_battle = t['statistics']['battles']
+ tank_win = t['all']['wins']
+ tank_battle = t['all']['battles']
mom = [L('none','%s/%s'%(jid,nick)), L('3 class','%s/%s'%(jid,nick)), L('2 class','%s/%s'%(jid,nick)), L('1 class','%s/%s'%(jid,nick)), L('master','%s/%s'%(jid,nick))][t['mark_of_mastery']]
if tank_battle:
msg += L('\n%s (%s/%s - %s%%), mastery: %s','%s/%s'%(jid,nick)) % (tanks_data[str(t['tank_id'])]['name_i18n'], tank_win, tank_battle, round(100.0*tank_win/tank_battle, 2), mom)
@@ -103,28 +111,28 @@ def wot(type, jid, nick, text):
except:
msg = L('Impossible to get tanks\' statistics','%s/%s'%(jid,nick))
else:
-
+
wins = stat['all']['wins']
battles = stat['all']['battles']
-
+
if not battles:
msg = '%s: %s/%s' % (wotname, wins, battles)
-
+
else:
try:
win_percent = round(100.0 * wins / battles, 2)
msg = '%s: %s/%s (%s%%)' % (wotname, wins, battles, win_percent)
-
+
np = int(win_percent) + 1
np_int = int((np * battles - 100 * wins) / (100 - np) + 1)
np05 = int(win_percent + 0.5) + 0.5
np_round = int((np05 * battles - 100 * wins) / (100 - np05) + 1)
-
+
msg += L('\nUp to %s%% win left: %s battles', '%s/%s'%(jid,nick)) % (np, np_int)
msg += L('\nUp to %s%% win left: %s battles', '%s/%s'%(jid,nick)) % (np05, np_round)
-
+
avg_exp = stat['all']['battle_avg_xp']
-
+
DAMAGE = stat['all']['damage_dealt'] / float(battles)
msg += L('\nAv. damage: %s','%s/%s'%(jid,nick)) % int(round(DAMAGE))
FRAGS = stat['all']['frags'] / float(battles)
@@ -135,62 +143,59 @@ def wot(type, jid, nick, text):
msg += L('\nAv. captured points: %s','%s/%s'%(jid,nick)) % round(CAP, 2)
DEF = stat['all']['dropped_capture_points'] / float(battles)
msg += L('\nAv. defense points: %s','%s/%s'%(jid,nick)) % round(DEF, 2)
-
-
- tanks = vdata['data'][player_id]
- s = sum([t['statistics']['all']['battles'] * tanks_data[str(t['tank_id'])]['level'] for t in tanks])
+ tanks = [vh for vh in vdata['data'][player_id] if vh['all']['battles']]
+ s = sum([t['all']['battles'] * tanks_data[str(t['tank_id'])]['level'] for t in tanks])
TIER = s / float(battles)
-
WINRATE = wins / float(battles)
-
msg += L('\nAv. tank lvl: %s','%s/%s'%(jid,nick)) % round(TIER, 2)
-
+
er = DAMAGE * (10 / (TIER + 2)) * (0.23 + 2 * TIER / 100) + FRAGS * 250 + SPOT * 150 + math.log(CAP + 1) / math.log(1.732) * 150 + DEF * 150
-
- if er < 420:
+ if er < 350:
er_xvm = 0
else:
- er_xvm = max(min(er*(er*(er*(er*(er*(4.5254e-17*er - 3.3131e-13) + 9.4164e-10) - 1.3227e-6) + 9.5664e-4) - 0.2598) + 13.23, 100), 0)
-
+ er_xvm = max(min(er*(er*(er*(er*(er*(3.388e-17*er - 2.469e-13) + 6.9335e-10) - 9.5342e-7) + 6.656e-4) -0.1485) - 0.85, 100), 0)
+
msg += L('\nEfficiency rating: %s (XVM: %s)','%s/%s'%(jid,nick)) % (int(round(er)), round(er_xvm, 1))
-
- if er < 630:
+
+ if er < 610:
msg += L(' - bad player','%s/%s'%(jid,nick))
- elif er < 860:
+ elif er < 850:
msg += L(' - player below average','%s/%s'%(jid,nick))
- elif er < 1140:
+ elif er < 1145:
msg += L(' - average player','%s/%s'%(jid,nick))
- elif er < 1460:
+ elif er < 1475:
msg += L(' - good player','%s/%s'%(jid,nick))
- elif er < 1735:
+ elif er < 1775:
msg += L(' - great player','%s/%s'%(jid,nick))
- elif er >= 1735:
+ elif er >= 1775:
msg += L(' - unicum','%s/%s'%(jid,nick))
-
+
wn6 = (1240 - 1040 / math.pow((min(TIER, 6)), 0.164)) * FRAGS + DAMAGE * 530 / (184 * math.exp(0.24 * TIER) + 130) + SPOT * 125 + min(DEF, 2.2) * 100 + ((185 / (0.17 + math.exp((WINRATE * 100 - 35) * -0.134))) - 500) * 0.45 + (6 - min(TIER, 6)) * (-60)
- if wn6 > 2160:
+ if wn6 > 2300:
wn6_xvm = 100
else:
- wn6_xvm = max(min(wn6*(wn6*(wn6*(-1.268e-11*wn6 + 5.147e-8) - 6.418e-5) + 7.576e-2) - 7.25, 100), 0)
-
+ wn6_xvm = max(min(wn6*(wn6*(wn6*(wn6*(wn6*(4.66e-18*wn6 - 3.2413e-14) + 7.524e-11) - 6.516e-8) + 1.307e-5) + 5.153e-2) - 3.9, 100), 0)
+
msg += L('\nWN6 rating: %s (XVM: %s)','%s/%s'%(jid,nick)) % (int(round(wn6)), round(wn6_xvm, 1))
-
- if wn6 < 425:
+
+ if wn6 < 410:
msg += L(' - bad player','%s/%s'%(jid,nick))
elif wn6 < 795:
msg += L(' - player below average','%s/%s'%(jid,nick))
- elif wn6 < 1175:
+ elif wn6 < 1185:
msg += L(' - average player','%s/%s'%(jid,nick))
- elif wn6 < 1570:
+ elif wn6 < 1585:
msg += L(' - good player','%s/%s'%(jid,nick))
- elif wn6 < 1885:
+ elif wn6 < 1925:
msg += L(' - great player','%s/%s'%(jid,nick))
- elif wn6 >= 1885:
+ elif wn6 >= 1925:
msg += L(' - unicum','%s/%s'%(jid,nick))
-
+
+ msg += L('\nWG rating: %s','%s/%s'%(jid,nick)) % pdata['data'][player_id]['global_rating']
+
stat_rnd = lambda x: stat['all'][x] - stat['clan'][x] - stat['company'][x]
-
+
armor = math.log(stat_rnd('battles')) / 10 * (stat_rnd('xp')/float(stat_rnd('battles')) + stat_rnd('damage_dealt')/float(stat_rnd('battles')) * (stat_rnd('wins') * 2 + stat_rnd('frags') * 0.9 + (stat_rnd('spotted') + stat_rnd('capture_points') + stat_rnd('dropped_capture_points')) * 0.5)/float(stat_rnd('battles')))
msg += L('\nArmor-rating: %s','%s/%s'%(jid,nick)) % int(round(armor))
@@ -198,7 +203,7 @@ def wot(type, jid, nick, text):
try:
data = load_page('http://armor.kiev.ua/wot/api.php?version=iSida3')
armor_limits = json.loads(data)
-
+
if armor > armor_limits['classRatings']['cv']:
msg += L(' - virtuoso','%s/%s'%(jid,nick))
elif armor > armor_limits['classRatings']['cm']:
@@ -232,29 +237,32 @@ def wot(type, jid, nick, text):
def wotclan(type, jid, nick, text):
text = text.strip().upper()
- try:
- data = load_page('%s/2.0/clan/list/?application_id=%s&search=%s' % (API_ADDR, APP_ID, text))
- data = json.loads(data)
- claninfo = [i for i in data['data'] if i['abbreviation'] == text]
- if claninfo:
- claninfo = claninfo[0]
- clid = claninfo['clan_id']
- owner = claninfo['owner_name']
- created_at = claninfo['created_at']
- abbrev = claninfo['abbreviation']
- data = load_page('%s/2.0/clan/info/?application_id=%s&clan_id=%s' % (API_ADDR, APP_ID, clid))
+ if text:
+ try:
+ data = load_page('%s/2.0/clan/list/?application_id=%s&search=%s' % (API_ADDR, APP_ID, text))
data = json.loads(data)
- claninfo2 = data['data'][str(clid)]
- msg = L('Name: %s [%s]','%s/%s'%(jid,nick)) % (claninfo2['name'], abbrev)
- msg += L('\nOwner: %s','%s/%s'%(jid,nick)) % owner
- msg += L('\nCreated at: %s','%s/%s'%(jid,nick)) % time.ctime(created_at)
- msg += L('\nCount of members: %s','%s/%s'%(jid,nick)) % claninfo2['members_count']
- msg += L('\nMotto: %s','%s/%s'%(jid,nick)) % claninfo2['motto']
- msg += '\n%s' % claninfo2['description']
- else:
- msg = L('Clan not found','%s/%s'%(jid,nick))
- except:
- msg = L('Impossible to get info','%s/%s'%(jid,nick))
+ claninfo = [i for i in data['data'] if i['abbreviation'] == text]
+ if claninfo:
+ claninfo = claninfo[0]
+ clid = claninfo['clan_id']
+ owner = claninfo['owner_name']
+ created_at = claninfo['created_at']
+ abbrev = claninfo['abbreviation']
+ data = load_page('%s/2.0/clan/info/?application_id=%s&clan_id=%s' % (API_ADDR, APP_ID, clid))
+ data = json.loads(data)
+ claninfo2 = data['data'][str(clid)]
+ msg = L('Name: %s [%s]','%s/%s'%(jid,nick)) % (claninfo2['name'], abbrev)
+ msg += L('\nOwner: %s','%s/%s'%(jid,nick)) % owner
+ msg += L('\nCreated at: %s','%s/%s'%(jid,nick)) % time.ctime(created_at)
+ msg += L('\nCount of members: %s','%s/%s'%(jid,nick)) % claninfo2['members_count']
+ msg += L('\nMotto: %s','%s/%s'%(jid,nick)) % claninfo2['motto']
+ msg += '\n%s' % claninfo2['description']
+ else:
+ msg = L('Clan not found','%s/%s'%(jid,nick))
+ except:
+ msg = L('Impossible to get info','%s/%s'%(jid,nick))
+ else:
+ msg = L('What?','%s/%s'%(jid,nick))
send_msg(type,jid,nick,msg)
def wotoffers(type, jid, nick, text):
@@ -273,7 +281,7 @@ def wotoffers(type, jid, nick, text):
except:
msg = L('Impossible to get info','%s/%s'%(jid,nick))
send_msg(type,jid,nick,msg)
-
+
global execute
execute = [(3, 'wot', wot, 2, 'World of Tanks - info about user. Usage: wot [nick [tank]]'),