@cnaize

Ошибка в string:substring в дате из базы?

У меня есть такой код:
get_items('GET', []) ->
	Items = boss_db:find(item, []),
	S = Req:query_param("start"),
	F = Req:query_param("finish"),
	Start = string_to_datetime(S),
	Finish = string_to_datetime(F),
	Fitems = filter(Items, Start, Finish, []),
	{json, [{items, Fitems}]}.

    create_item('POST', []) ->
	Lastname = Req:post_param("lastname"),
	User = hd(boss_db:find(consumer, [{lastname, Lastname}])),
	DateTime = datetime_to_string(calendar:now_to_local_time(erlang:now())),
	Type = Req:post_param("type"),
	IdType = Req:post_param("idtype"),
	Item = item:new(id, User:id(), DateTime, Type, IdType),
	case Item:save() of
		{ok, SavedItem} -> {json, [{status, "ok"}]};
		{error, Reason} -> {json, [{error, Reason}]}
	end.

    datetime_to_string({{YY, MM, DD}, {Hour, Min, Sec}}) -> 
    io_lib:format("~4..0w-~2..0w-~2..0w ~2..0w:~2..0w:~2..0w",
    	[YY, MM, DD, Hour, Min, Sec]).

    string_to_datetime(S) ->
	{YY, _} = string:to_integer(string:substr(S, 1, 4)),
	{MM, _} = string:to_integer(string:substr(S, 6, 2)),
	{DD, _} = string:to_integer(string:substr(S, 9, 2)),
	{Hour, _} = string:to_integer(string:substr(S, 12, 2)),
	{Min, _} = string:to_integer(string:substr(S, 15, 2)),
	{Sec, _} = string:to_integer(string:substr(S, 18, 2)),
	{{YY, MM, DD}, {Hour, Min, Sec}}.

    filter([], Start, Finish, Acc) -> Acc;
    filter([Model|Models], Start, Finish, Acc) ->
	DateTime = string_to_datetime(Model:datetime()),
	{D1, _} = calendar:time_difference(Start, DateTime),
	{D2, _} = calendar:time_difference(DateTime, Finish),
	if
		D1 >= 0, D2 >= 0 -> filter(Models, Start, Finish, [Model | Acc]);
		true -> filter(Models, Start, Finish, Acc)
	end.


И получаю такую ошибку:

{function_clause,
        [{string,substr2,
             [<<"2013-12-17 18:36:42">>,1],
             [{file,"string.erl"},{line,213}]},
         {string,substr,3,[{file,"string.erl"},{line,208}]},
         {cb_tracker_main_controller,string_to_datetime,2,

Пожалуйста, помогите, уже столько мучаюсь. Хотя бы знать бы, в какую сторону копать.
  • Вопрос задан
  • 2787 просмотров
Пригласить эксперта
Ответы на вопрос 1
@pfi79
Вы используете string:substr, которая ожидает на вход список, а вы на вход подаете бинарную строку - <<"2013-12-17 18:36:42">>.
Используйте бинарный патерн мачинг:
string_to_datetime(<<YY:4/binary,_:1/binary,MM:2/binary,"и т.д.",_/binary >>) -> ....

А может не стоит в вашем случае использовать списки, может бинари лучше?
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы