2016-10-17 3 views
2

Я обрабатываю данные из внешнего API. Он возвращает временные метки как формат ISO 8601, с часовым поясом.ISO 8601 как формат ввода для Ecto.DateTime.cast()

Мое понимание заключается в том, что Ecto версии 2.1-rc (моя версия) может обрабатывать такие временные метки без проблем. Однако, когда я пытаюсь выполнить:

created_at = Ecto.DateTime.cast!("2016-10-16T21:21:27-04:00") 

Я получаю сообщение об ошибке:

(Ecto.CastError) cannot cast "2016-10-16T21:21:27-04:00" to datetime 

Есть ли проблема с моей отметкой времени?

ответ

2

Ваш формат не указан для Ecto.DateTime.cast. Пожалуйста, проверьте здесь it.

Это:

created_at = Ecto.DateTime.cast!("2016-10-16T21:21:27") 

не выбросит ошибку.

Запрещается использование -. Теперь вам решать использовать другие действительные даты и времени ISO-8601 без знака - или просто пропустить его.

+0

Вы, казалось, удалили часовой пояс все вместе, а не только тире. Есть ли способ правильно представить часовой пояс здесь? –

5

Ваша временная метка действительна ISO 8601, но Ecto не поддерживает синтаксический анализ таких дат с v2.1.0-rc.2. Вы можете использовать другие библиотеки, такие как timex, чтобы проанализировать их, конвертировать в UTC, а затем сохранить их в Ecto.

iex(1)> "2016-10-16T21:21:27-04:00" |> Timex.parse!("{ISO:Extended}") 
#<DateTime(2016-10-16T21:21:27-04:00 Etc/GMT+4)> 
iex(2)> "2016-10-16T21:21:27-04:00" |> Timex.parse!("{ISO:Extended}") |> Timex.to_datetime 
#<DateTime(2016-10-17T01:21:27Z Etc/UTC)> 

С Ecto 2.1, вы можете сохранить это значение непосредственно в поле :utc_datetime:

iex(1)> created_at = "2016-10-16T21:21:27-04:00" |> Timex.parse!("{ISO:Extended}") |> Timex.to_datetime 
#<DateTime(2016-10-17T01:21:27Z Etc/UTC)> 
iex(2)> Repo.insert!(%Person{created_at: created_at}) 
12:58:39.959 [debug] QUERY OK db=2.5ms 
INSERT INTO "people" ("created_at","inserted_at","updated_at") VALUES ($1,$2,$3) RETURNING "id" [{{2016, 10, 17}, {1, 21, 27, 0}}, {{2016, 10, 17}, {7, 28, 39, 945106}}, {{2016, 10, 17}, {7, 28, 39, 948505}}] 
%Friends.Person{__meta__: #Ecto.Schema.Metadata<:loaded, "people">, age: nil, 
created_at: #<DateTime(2016-10-17T01:21:27Z Etc/UTC)>, first_name: nil, id: 1, 
inserted_at: ~N[2016-10-17 07:28:39.945106], last_name: nil, 
updated_at: ~N[2016-10-17 07:28:39.948505]}