Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
103 / 90 / 75
Регистрация: 04.11.2011
Сообщений: 1,820
1

Возвращение нескольких значений функцией

12.05.2019, 22:50. Показов 548. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Есть функция, вызывается следующим образом
PHP
1
$Responce=create_orders($mysqli,$sesion_id,$contest_id,$price,$amount,$name_val,$name_prod,$type_operation);
Можно ли написать еще 1 функцию, например data(), которая в свою очередь будет возвращать все необходимые переменные для функции create_orders, ну и собственно использовать функцию data как единственный аргумент функции create_orders?
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
12.05.2019, 22:50
Ответы с готовыми решениями:

Возвращение значений из функции
Добрый день! Есть индексный файл в котором происходит начало сессии, подключаются библиотека с...

Несколько значений, возвращаемых функцией
Могут ли функции в PHP возвращать несколько значений?

Изменение значений массивов функцией
Добрый день! Начал изучение пхп. Сейчас стоит задача изменить значения массива. Вот такой код....

Передача нескольких значений
Есть допустим куча чекбоксов: <input type="checkbox" value="1" name="checkbox"...

3
Эксперт PHP
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
12.05.2019, 22:52 2
https://www.php.net/manual/ru/... ures.splat
0
103 / 90 / 75
Регистрация: 04.11.2011
Сообщений: 1,820
12.05.2019, 23:15  [ТС] 3
Вы меня не так поняли, сейчас подробнее опишу. Есть код
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
 function rand_float($st_num=0,$end_num=1,$mul=1000000)
{
if ($st_num>$end_num) return false;
return mt_rand($st_num*$mul,$end_num*$mul)/$mul;
}
 
$num= rand(1,3);
include_once('db_connect.php');
for ($i = 0; $i < $num; $i++) {
$req = $mysqli->query("SELECT * FROM `coinInfo` WHERE coinName = 'BTC'");
while($row = $req->fetch_assoc()) {
$ask = $row["ask"]/100000000;
$bid = $row["bid"]/100000000;
}
$operation = array("BUY", "SELL");
$rand_keys = array_rand($operation);
 
//
 
$int = mt_rand(1,4)/10000;
$fractional = mt_rand(1,99) / 10000;
$float = $int + $fractional;
 
$price          = rand_float($bid,$ask);
$amount         = $float;
$type_operation =  $operation[$rand_keys];
 
$Responce=create_orders($mysqli,$sesion_id = 299,$contest_id = 1,$price,$amount,$name_val = 'USD',$name_prod = 'BTC',$type_operation);  
}
По итогу он создает ордера(от 1 до 3) на продажу и покупку. Мне нужно продублировать его для нескольких $name_prod(их будет штук 20). И я хочу написать функцию, которая будет иметь единственный аргумент coinName, используется в запросе
PHP
1
$req = $mysqli->query("SELECT * FROM `coinInfo` WHERE coinName = 'BTC'");
и эта новая функция будет возвращать весь набор необходимых переменных для create_orders. По идее должно вызов должен выглядеть как-то так: create_orders(data(btc))(если такое возможно вообще). Цель такая, чтобы не дублировать по 15 строк кода, а по 2, для каждой coinName
0
1084 / 746 / 364
Регистрация: 09.07.2018
Сообщений: 1,760
13.05.2019, 09:02 4
Xo6ut, схематический пример:
Кликните здесь для просмотра всего текста
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
$args = getArgs('BTC');
/* Результат - ассоциативный массив:
Array
(
    [coinName] => BTC
    [mysqli] => SELECT * FROM `coinInfo` WHERE `coinName` = 'BTC'
    [sesion_id] => 299
    [contest_id] => 1
    [price] => price
    [amount] => amount
    [name_val] => USD
    [name_prod] => BTC
    [type_operation] => type_operation
)
*/
 
$responce = create_orders($args);
print_r($responce);
/* Результат - результат вычислений (для примера, просто строка со значениями переменных):
SELECT * FROM `coinInfo` WHERE `coinName` = 'BTC' 299 1 price amount USD BTC type_operation
*/
 
function getArgs(string $coinName): array
{
    $mysqli = "SELECT * FROM `coinInfo` WHERE `coinName` = '$coinName'";
    $sesion_id = 299;
    $contest_id = 1;
    $price = 'price';
    $amount = 'amount';
    $name_val = 'USD';
    $name_prod = 'BTC';
    $type_operation = 'type_operation';
 
    return get_defined_vars();
}
 
function create_orders(array $args)
{
    extract($args);
 
    return "$mysqli, $sesion_id, $contest_id, $price, $amount, $name_val, $name_prod, $type_operation";
}
0
13.05.2019, 09:02
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
13.05.2019, 09:02
Помогаю со студенческими работами здесь

Использование нескольких значений explode
Допустим есть в базе данных две ячейки с именами units и price которые хранятся в следующем виде: ...

Выбор нескольких значений из базы
Необходимо сделать запрос к базе данных с выбором только тех строк, которые необходимы. Первый...

Вывод нескольких значений из БД в переменную
Добрый день! Помогите решить проблему. Есть 2 таблицы, первая &quot;items&quot;, вторая &quot;items_have&quot;....

Str_replace замена нескольких значений
Решил не заморачиваться с текстовыми редакторами, а если нужно, писать теги. Но хочу сделать на...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru