Я читаю массив из БД и хочу отформатировать его, чтобы предоставить таблицу, похожую на текст, для моего бота-телеграммы.
Я пытаюсь использовать функцию sprintf php для форматирования текста, но когда япопытаться поместить результат в строку. В результате любая строка будет помещена в строку.
Это мой массив:
// This is my complete array.
{
"result":true,
"error":"nothing",
"content":{
"3269":{"Quantity":4,"Name":"Atom Seikhart"},
"3273":{"Quantity":4,"Name":"Brunhild"},
"3304":{"Quantity":3,"Name":"Isis"},
"3319":{"Quantity":1,"Name":"Arthur"},
"3329":{"Quantity":2,"Name":"Loki"},
"3343":{"Quantity":1,"Name":"Chamimi"},
"3351":{"Quantity":14,"Name":"Hanzo"},
"3379":{"Quantity":8,"Name":"Lucifer"}
},
"Total":37
}
И это мой цикл php и отправка сообщения:
// This is my "select from db" function.
$res = get_event_rulers_breakdowns_by_id($mysqli, $value["Id"]);
$breakdown = $res["content"];
$message .= "\nThis is the event ruler breakdown (total " . $res["Total"] . "):\n";
foreach ($breakdown as $value) {
$perc = round($value["Quantity"] / $res["Total"] * 100, 2);
$stringa = "%+4s:%+4d\t(<code>%+4g%</code>)\n";
// This work but don't format the text.
$message .= $value["Name"] . ":\t" . $value["Quantity"] . " (<code>" . $perc . "%</code>)\n";
// This dosen't work.
$formatt = sprintf("%+4s:%+4d (<code>%+4g%</code>)", $value["Name"], $value["Quantity"], $perc);
// This dosen't work too.
$formatt = sprintf("%+4s:%+4d (<code>%+4g%</code>)", "aa", 123, 12.3);
$message .= $formatt . "\n";
}
Фактический результат:
И ожидаемый результат будет таким:
Atom Seikhart: 4 (10.81%)
Brunhild: 4 (10.81%)
Isis: 3 (8.11%)
Arthur: 1 (2.7%)
Loki: 2 (5.41%)
Chamimi: 1 (2.7%)
Hanzo: 14 (37.84%)
Lucifer: 8 (21.62%)
или как:
Atom Seikhart: 4 (10.81%)
Brunhild: 4 (10.81%)
Isis: 3 (8.11%)
Arthur: 1 (2.7%)
Loki: 2 (5.41%)
Chamimi: 1 (2.7%)
Hanzo: 14 (37.84%)
Lucifer: 8 (21.62%)