Arhn - архитектура программирования

Лучший способ пройтись по набору хэшей, присваивая значения массива в Ruby

Я пытаюсь вставить данные в Postgres. У меня есть массив данных, и я пытаюсь присвоить каждому столбцу значение массива. Вот пример.

pg_insert = ['12/09/2015', 41, 'test account', '41.0']
Table.create([date: pg_insert[0],
            account_number: pg_insert[1],
            account_name: pg_insert[2],
            values: pg_insert[3]])

Есть ли способ, где я могу зациклить это, чтобы я мог поместить i в pg_insert вместо того, чтобы вводить числа? Я не уверен, как зациклиться внутри параметра create(). Есть ли способ обойти это?

Любые предложения будут большим спасибо.


  • Просто подтверждаю, вы действительно имеете в виду Table.create([...])? pg_insert - это массив строк, но аргумент :create кажется, что вы имели в виду хэш. Если это должен быть хэш, я думаю, у меня есть идея для вас... 10.12.2015
  • Что бы ни загружалось. Я думаю, что это работает в обе стороны. 10.12.2015
  • Table.create(date: pg_insert[0], account_number: pg_insert[1]) работает, если это то, о чем вы спрашивали. 10.12.2015

Ответы:


1

Table.create принимает хеш, я уверен.

Итак, вот что вы можете сделать:

  1. Создайте массив с именем keys, содержащий 4 символа :date, :account_number, :account_name и :values.
  2. pg_insert уже является массивом.
  3. Теперь вы можете объединить два массива, чтобы получить нужный вам хеш: Hash[keys.zip(pg_insert)]
  4. Это позволяет вам вызывать Table.create следующим образом: Table.create(Hash[keys.zip(pg_insert)])

Вот готовый код тогда:

keys = [:date, :account_number, :account_name, :values]
pg_insert = ['12/09/2015', 41, 'test account', '41.0']
Table.create(Hash[keys.zip(pg_insert)])  # or Table.create Hash[keys.zip(pg_insert)]  if you don't want so many parentheses.

Обратите внимание, что pg_insert всегда должно быть в том же порядке, что и keys.

Вы можете прочитать больше об Array#zip и Hash.new, чтобы понять, как они работают. Эта ссылка SO также может быть полезна: -in-ruby">Преобразование массива ключей и массива значений в хеш в Ruby

10.12.2015
  • Да, мне потребовалось некоторое время, чтобы вернуться к этому сценарию, но как только я попробовал его, он сработал. Спасибо! 23.12.2015
  • Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..