- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我制作了一个脚本,从数据库中获取数据,然后使用数据库中每个玩家的数据来计算技能级别和添加到数组中的其他参数。然后,该数组中的所有数据都会输入到我的数据库中的表格中作为顶部列表。
现在我的问题是它在本地主机上运行,有 0 个错误,但是当我在我的服务器上运行它时,它似乎只运行到:
echo $calculatediamondgrade." + ".$calculatediamondgradeforamted." + ".$summonerData->name."<br>";
我正在努力让它工作,我在我的编码中没有发现任何问题,有人可以看一下并让我思考你的想法。
<?php
set_time_limit(0);
require_once 'connect_db.php';
$emptyQuery = "TRUNCATE top_list;";
if ($conn->query($emptyQuery)) {
$sql = "SELECT summoner_info, tier_info, ranked_champs_info FROM players_data";
$result = $conn->query($sql);
if ($result->num_rows > 0) {
$players = array();
$champsPoints = array();
while ($row = $result->fetch_assoc()) {
$summonerData = unserialize($row['summoner_info']);
$tierData = unserialize($row['tier_info']);
if ($tierData == NULL || !isset($tierData)) {
$tierData = new stdClass();
$tierData->tier = 'UNRANKED';
$tierEntry = new stdClass();
$tierEntry->division = '';
} else {
$tierData = $tierData[0];
$tierEntry = $tierData->entries[0];
}
$ranked_champs_infoData = unserialize($row['ranked_champs_info']);
if ($row['summoner_info'] !== "N;") {
if ($row['ranked_champs_info'] !== "N;") {
foreach ($ranked_champs_infoData->champions as $champData) {
$champIDs = $champData->id;
if (!$champIDs == 0) {
$totalsessionsplayedwithachampion = $champData->stats->totalSessionsPlayed;
if ($totalsessionsplayedwithachampion >= 10) {
$champstotalSessionsWon = $champData->stats->totalSessionsWon;
$champstotalSessionsLost = $champData->stats->totalSessionsLost;
$getMiniomskillsNamelistside = $champData->stats->totalMinionKills;
$KDAMinniomsSide = $getMiniomskillsNamelistside / ($totalsessionsplayedwithachampion);
if (isset($champData->stats) && isset($champData->stats->totalChampionKills)) {
/* Champion total kills */
$champsdatazkillz = $champData->stats->totalChampionKills;
} else {
$champsdatazkillz = 0;
}
if (isset($champData->stats) && isset($champData->stats->totalAssists)) {
/* Champion total assists */
$champsdatazassitsz = $champData->stats->totalAssists;
} else {
$champsdatazassitsz = 0;
}
if (isset($champData->stats) && isset($champData->stats->totalDeathsPerSession)) {
/* Champion total deaths */
$champsdatazdeathz = $champData->stats->totalDeathsPerSession;
} else {
$champsdatazdeathz = 0;
}
if ($champsdatazdeathz == 0) {
$KDAsidechamps = ($champsdatazkillz + $champsdatazassitsz);
} else {
$KDAsidechamps = ($champsdatazkillz + $champsdatazassitsz) / $champsdatazdeathz;
}
if ($tierData->tier == "CHALLENGER") {
$championrankMOD = '1.9';
$championrankKDA = 0.95;
$championrankKDAminniom = 0.0095;
} else if ($tierData->tier == "MASTER") {
$championrankMOD = '1.85';
$championrankKDA = 0.93;
$championrankKDAminniom = 0.0093;
} else if ($tierData->tier == "DIAMOND") {
$championrankMOD = '1.8';
$championrankKDA = 0.9;
$championrankKDAminniom = 0.0090;
} else if ($tierData->tier == "PLATINUM") {
$championrankMOD = '1.7';
$championrankKDA = 0.86;
$championrankKDAminniom = 0.0087;
} else if ($tierData->tier == "GOLD") {
$championrankMOD = '1.65';
$championrankKDA = 0.82;
$championrankKDAminniom = 0.0085;
} else if ($tierData->tier == "SILVER") {
$championrankMOD = '1.55';
$championrankKDA = 0.75;
$championrankKDAminniom = 0.0083;
} else if ($tierData->tier == "BRONZE") {
$championrankMOD = '1.45';
$championrankKDA = 0.71;
$championrankKDAminniom = 0.0080;
} else if ($tierData->tier == "UNRANKED") {
$championrankMOD = '1.55';
$championrankKDA = 0.75;
$championrankKDAminniom = 0.0083;
}
$calculatediamondgrade = ((pow(number_format((float)$KDAsidechamps, 2, '.', ''), 1 / 2) * $championrankKDA) + (pow(number_format((float)$KDAMinniomsSide, 2, '.', ''), 1 / 20) * $championrankKDAminniom)) * pow((($champstotalSessionsWon + 0.5) / (($champstotalSessionsWon + 0.4) + ($champstotalSessionsLost + 0.3))), 1 / 1.1) * pow((($champstotalSessionsWon) + ($champstotalSessionsLost - 0.4)), 1 / 8) * $championrankMOD;
$calculatediamondgradeforamted = number_format((float)$calculatediamondgrade, 3, '.', '') * (1000);
echo $calculatediamondgrade . " + " . $calculatediamondgradeforamted . " + " . $summonerData->name . "<br>";
array_push($players, array(
'champId' => $champData->id,
'profileiconid' => $summonerData->profileIconId,
'playerName' => $summonerData->name,
'tier' => $tierData->tier,
'division' => $tierEntry->division,
'championPoints' => $calculatediamondgradeforamted,
'gamesplayed' => $totalsessionsplayedwithachampion
));
array_push($champsPoints, $calculatediamondgradeforamted);
}
}
}
}
}
}
rsort($champsPoints);
usort($players, function ($a, $b) use ($champsPoints) {
$pos_a = array_search($a['championPoints'], $champsPoints);
$pos_b = array_search($b['championPoints'], $champsPoints);
return $pos_a - $pos_b;
});
$championsPoints = array_values(array_unique($champsPoints));
$playersByCP = array();
foreach ($championsPoints as $champsPoint) {
$sameCPs = array();
foreach ($players as $player) {
$sameCP = array();
if ($player['championPoints'] == $champsPoint) {
switch ($player['tier']) {
case 'BRONZE':
switch ($player['division']) {
case 'I':
$sameCP['tier'] = 'z5';
break;
case 'II':
$sameCP['tier'] = 'z4';
break;
case 'III':
$sameCP['tier'] = 'z3';
break;
case 'IV':
$sameCP['tier'] = 'z2';
break;
case 'V':
$sameCP['tier'] = 'z1';
break;
default:
$sameCP['tier'] = 'Error Bronze';
break;
}
break;
case 'SILVER':
switch ($player['division']) {
case 'I':
$sameCP['tier'] = 'y5';
break;
case 'II':
$sameCP['tier'] = 'y4';
break;
case 'III':
$sameCP['tier'] = 'y3';
break;
case 'IV':
$sameCP['tier'] = 'y2';
break;
case 'V':
$sameCP['tier'] = 'y1';
break;
default:
$sameCP['tier'] = 'Error Silver';
break;
}
break;
case 'GOLD':
switch ($player['division']) {
case 'I':
$sameCP['tier'] = 'x5';
break;
case 'II':
$sameCP['tier'] = 'x4';
break;
case 'III':
$sameCP['tier'] = 'x3';
break;
case 'IV':
$sameCP['tier'] = 'x2';
break;
case 'V':
$sameCP['tier'] = 'x1';
break;
default:
$sameCP['tier'] = 'Error Gold';
break;
}
break;
case 'PLATINUM':
switch ($player['division']) {
case 'I':
$sameCP['tier'] = 'w5';
break;
case 'II':
$sameCP['tier'] = 'w4';
break;
case 'III':
$sameCP['tier'] = 'w3';
break;
case 'IV':
$sameCP['tier'] = 'w2';
break;
case 'V':
$sameCP['tier'] = 'w1';
break;
default:
$sameCP['tier'] = 'Error Platinum';
break;
}
break;
case 'DIAMOND':
switch ($player['division']) {
case 'I':
$sameCP['tier'] = 'v5';
break;
case 'II':
$sameCP['tier'] = 'v4';
break;
case 'III':
$sameCP['tier'] = 'v3';
break;
case 'IV':
$sameCP['tier'] = 'v2';
break;
case 'V':
$sameCP['tier'] = 'v1';
break;
default:
$sameCP['tier'] = 'Error Diamond';
break;
}
break;
case 'MASTER':
$sameCP['tier'] = 'u';
break;
case 'CHALLENGER':
$sameCP['tier'] = 'u';
break;
default:
$sameCP['tier'] = 'Error Tier';
break;
}
$sameCP['player'] = $player;
array_push($sameCPs, $sameCP);
}
}
sort($sameCPs);
foreach ($sameCPs as $sameCP) {
array_push($playersByCP, $sameCP['player']);
}
}
foreach ($playersByCP as $position => $playerByCP) {
$tableRow = serialize($playerByCP);
if ($playerByCP['gamesplayed'] >= 10) {
$sql2 = 'INSERT INTO top_list (position, table_row, sum_name, champ_id) VALUES (' . $position . ', \'' . $tableRow . '\', \'' . mb_strtolower(str_replace(' ', '', $playerByCP['playerName']), 'UTF-8') . '\', \'' . mb_strtolower(str_replace(' ', '', $playerByCP['champId']), 'UTF-8') . '\')';
if ($conn->query($sql2)) {
echo 'Insert: ' . mb_strtolower(str_replace(' ', '', $playerByCP['playerName']), 'UTF-8') . '<br>';
} else {
echo 'Failed: ' . $conn->error . '<br>';
}
}
}
}
}
?>
最佳答案
编辑 php.ini 时,请确保您正在编辑的文件正确。看看这里:How to know which php.ini is used?
尝试在服务器配置文件中显式设置执行时间:
max_execution_time = 360
特定服务器配置可能会处理与本地主机不同的默认值。
关于Php 脚本在本地主机上完全工作,只有部分在服务器上工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43101368/
我在这里想做的是将所有连接转发到机器一上端口 3306 上的本地主机到本地主机上端口 3306 上的机器二。因此,如果您连接到机器一上的 mysql,它的行为就像您正在连接一样在二号机器上。 我认为
通过Kibana界面,如何获得 flex IP /主机? 我的意思是,与kibana连接的Elastic主机。 那有可能吗?我在这个上挣扎了好几个小时,却一无所获:( 附:不确定此问题是否是题外话,应
我知道这听起来很奇怪,但我有一个情况,Deno 需要关闭自己的主机(并因此杀死自己的进程)。这可能吗? 我特别需要这个用于 linux (lubuntu),如果相关的话。我想这需要 sudo 权限,这
我知道这听起来很奇怪,但我有一个情况,Deno 需要关闭自己的主机(并因此杀死自己的进程)。这可能吗? 我特别需要这个用于 linux (lubuntu),如果相关的话。我想这需要 sudo 权限,这
我有一个基本问题,但谷歌并没有为我产生很多结果(反正不是英文的)。基本上我想做的就是: 我有一个图形需要用作整个应用程序的持久 header ,例如:我不能让它在新的 Intent 调用时从屏幕上滑出
您好,我正在使用 xampp,我正在尝试使用 php 进行连接。 $sql_connections = mysql_connect("$server, $username, $password")
我目前正在尝试一些多人游戏的想法,并正在尝试创建一个 Java 应用程序来为基于网络浏览器的多人游戏提供服务。 我的开发环境是主机上的Eclipse, native 上的notepad + Googl
今天为大家分享一篇关于SSH 的介绍和使用方法的文章。本文从SSH是什么出发,讲述了SSH的基本用法,之后在远程登录、端口转发等多种场景下进行独立的讲述,希望能对大家有所帮助。 什么是SSH?
我已经完成了在裸机 Centos 7 上运行的测试 Kubernets 主机的设置。这将用作测试系统,因为我们将在 IBM Bluemix Kubernetes 服务中部署所有内容。 从 Bluemi
我正在尝试通过带有 4.2(果冻 bean )的 android 设备“nexus 7”通过 USB 与我的 freeduino 板进行通信,该板类似于 arduino uno。 几个月后,我使用开发
我正在使用 nginx,但在设置反向代理时遇到问题。 我的 nginx.conf 是默认的(没有对其进行任何更改),我的站点可用配置是: upstream backend_hosts { se
我在 projectlocker(免费 svn 主机)上有一个帐户,但我不知道如何将我的项目文件上传到它。 我在我的仪表板中找不到任何选项。 我在我的电脑上使用tortoiseSvn,那么如何上传文件
设置batchSize = 1有意义吗?如果我想一次处理一个文件? 尝试过batchSize = 1000和batchSize = 1 - 似乎具有相同的效果 { "version": "2.0"
我只想知道.. docker中现在有任何可用的工具吗?我已经阅读了Docker中有关多主机功能的一些文档,例如, Docker群 Docker服务(带有副本) 我也知道群模式下的volume问题,容器
我想将文件从 Docker 的容器挂载到我的 docker 主机。 数据卷不是我的解决方案,因为它们是从 docker 主机到 docker 容器的装载,我需要相反的方法。 谢谢 最佳答案 当 doc
我是新手。我无法正确理解RMI。互联网上有大量教程,但据我所知,它们都是针对本地主机的。服务器和客户端都运行在同一台机器上。 我想在任何计算机上运行客户端,并且主机将位于一台计算机上,让我们考虑IP
我无法从客户端“A”SSH 到服务器“B”(但我可以从同一子网上的许多其他 ssh 客户端而不是“A”——所有都是 *nux 机器) serverA>ssh -v -p 端口用户@serverB Op
设置batchSize = 1有意义吗?如果我想一次处理一个文件? 尝试过batchSize = 1000和batchSize = 1 - 似乎具有相同的效果 { "version": "2.0"
由于我不是天生的编码员,请多多包涵。 这是我尝试使用HAproxy来实现的目标,但是经过数小时的检查后,我无法以某种方式使其工作。 从 domain.com/alpha domain.com/beta
我正在使用 tomcat 运行 Java Web 应用程序,通过电子邮件将生成的报告发送给用户。我可以发送电子邮件,但几个小时后服务器停止发送电子邮件,并出现以下错误。 javax.mail.Mess
我是一名优秀的程序员,十分优秀!