Как обращаться к столбцам переменных SQL-запроса с помощью TWIG

Я пытаюсь обратиться к определенному столбцу SQL-запроса в зависимости от значения другой строки из запроса.

Результат, который я получаю из SQL-запроса, выглядит примерно так:

Number | Value1 | Value2 | Value3 
1      |      3 |      5 |     4
3      |      5 |      2 |     6
2      |      1 |      3 |     2

Для каждой строки я хочу получить значение столбца по индексу числа. Так, например, в первой строке я хочу получить значение «Значение1», равное 3. Во второй строке я хочу получить значение «Value3», равное 6, и так далее.

Затем я перебираю список с помощью цикла TWIG for и могу получить доступ к параметру «Число» следующим образом:

{% for key in examplelist|keys %}
   {% set number = examplelist[key].number %}
{% endfor %}

К сожалению, я не могу обращаться к столбцам «Значение», используя этот номер.

Я пробовал такие вещи, как:

{{examplelist[key].Value . number }}

или

{{examplelist[key].Value + number }}

или

{{examplelist[key].Value ~ number }}

но ни один из них не работает...

Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
2
0
150
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

это должно помочь

{% for key in examplelist|keys %}
   {% set number = examplelist[key].number %}
   {% set value  = examplelist[key]["Value"~number] %}
{% endfor %}

«как-то не работает» не дает много информации для работы :) - это решение работает с аналогичными простыми данными массива, как показано в вашем вопросе (я тестировал это с веткой 2.6). Итак, что вы получаете как ошибку из вышеизложенного? или от сброса значения "value" сверху? Или что именно означает, что это как-то не работает? И можете ли вы сбросить всю переменную «examplelist», чтобы увидеть, в каком формате у вас есть данные.

ejuhjav 27.05.2019 11:27
Ответ принят как подходящий

Хорошо, я понял это.

Данные возвращаются как объект типа stdClass, а не как массив. Поэтому вы не можете получить к нему доступ как к массиву, и его необходимо преобразовать с помощью

$Examplelist = json_decode($Examplelist, true);
return $Examplelist;

в части php.

После этого его можно решить с помощью

{% set value  = examplelist[key]["Value"~number] %}

Спасибо за помощь в любом случае :)

Другие вопросы по теме