Распечатать название функции имеет наибольшее значение - PullRequest
0 голосов
/ 09 июня 2018

Моя 3 различных функции дали мне значение, как показано ниже: JSON.

enter image description here

Я хочу ПЕЧАТЬ имени function который имеет наибольшее значение .Функции:

public function firstHourTrades()
{
    $user_id = Auth::user()->id;
    $data = DB::table('finaltrade')
        ->select(DB::raw('count(*) as first_hour'))
        ->join('exchanges', 'finaltrade.exchange_id', '=', 'exchanges.id')
        ->where('finaltrade.user_id', $user_id)
        ->whereTime(DB::raw('IF(finaltrade.buy_datetime<finaltrade.sell_datetime, finaltrade.buy_datetime, finaltrade.sell_datetime) '), '>=', DB::raw('exchanges.start_time'))
        ->whereTime(DB::raw('IF(finaltrade.buy_datetime<finaltrade.sell_datetime, finaltrade.buy_datetime, finaltrade.sell_datetime) '), '<=', DB::raw("ADDTIME(exchanges.start_time, '1:00:00')"))
        ->get();

    return response()->json($data);
}

public function lastHourTrades()
{
    $user_id = Auth::user()->id;
    $data = DB::table('finaltrade')
        ->select(DB::raw('count(*) as last_hour'))
        ->join('exchanges', 'finaltrade.exchange_id', '=', 'exchanges.id')
        ->where('finaltrade.user_id', $user_id)
        ->whereTime(DB::raw('IF(finaltrade.buy_datetime<finaltrade.sell_datetime, finaltrade.buy_datetime, finaltrade.sell_datetime) '), '<=', DB::raw('exchanges.close_time'))
        ->whereTime(DB::raw('IF(finaltrade.buy_datetime<finaltrade.sell_datetime, finaltrade.buy_datetime, finaltrade.sell_datetime) '), '>=', DB::raw("SUBTIME(exchanges.close_time, '01:00:00')"))
        ->get();
    return response()->json($data);
}

public function otherHoursTrades()
{
    $user_id = Auth::user()->id;
    $data = DB::table('finaltrade')
        ->select(DB::raw('count(*) as other_hours'))
        ->join('exchanges', 'finaltrade.exchange_id', '=', 'exchanges.id')
        ->where('finaltrade.user_id', $user_id)
        ->whereRaw('finaltrade.created_at NOT BETWEEN exchanges.start_time AND DATE_ADD(exchanges.start_time, INTERVAL 1 HOUR)')
        ->whereRaw('finaltrade.created_at NOT BETWEEN exchanges.close_time AND DATE_SUB(exchanges.close_time, INTERVAL 1 HOUR)')
        ->get();

    return response()->json($data);
}

ОТ ОТВЕТА, который Я СОЗДАЛ:

public function allCmp()
{

$func_names  = ['firstHourTrades()','lastHourTrades()','otherHoursTrades()'];

foreach($func_names as $name)
    $results[$name] = $name();

$max       = max($results);

DD($max);

}

1 Ответ

0 голосов
/ 09 июня 2018
<?php

function one()
{
    return 1;
}
function two()
{
    return 2;
}
function three()
{
    return 3;
}

$func_names = ['three','one','two'];
// Call each function and store result.
foreach($func_names as $name)
    $results[$name] = $name();

$max       = max($results);
$max_funcs = array_keys($results, $max);

var_dump($max_funcs);

Вывод:

array(1) {
  [0]=>
  string(5) "three"
}

Возможно, вам потребуется декодировать JSON в какой-то момент, например:

function get_val_from_my_json($json) {
    return array_values(json_decode($json, true))[0];
}

print get_val_from_my_json('{"some_key":5}');

Вывод:

5

И пропустите все результаты через эту функцию (при условии действительного json).

$results = array_map('get_val_from_my_json', $results);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...