Elixir中的日期排序列表

标签 sorting date calendar elixir

我整理了一个小脚本来帮助我进行伤害恢复过程。它输出了我期望的结果,但是日期似乎没有按照我期望的那样排序-看起来按月/日排序是可行的,但不是按年份排序。如果仅排序日期列表而不使用结构,则结果相同。

旁注,使用https://github.com/lau/calendar填充我的日期范围。

defmodule Phase do
  defstruct day: "", weight: "" 
end

defmodule Recovery do
  alias Calendar.Date

  def phases(start_date, end_date, start_weight, increase_by) do
    # Get the range of dates
    date_range = Date.days_after_until(start_date, end_date, true) |> Enum.to_list

    # build all phases, starting at day 0
    values = do_phases(date_range, [], start_weight, increase_by)
    Enum.sort_by(values, &(&1.day))
  end

  defp do_phases([], recovery_plan, _weight, _increase_by), do: recovery_plan 
  defp do_phases([head | tail], recovery_plan, weight, increase_by) do
    v = [%Phase{day: head, weight: weight} | recovery_plan]
    do_phases(tail, v, weight + increase_by, increase_by)
  end
end

在iex中运行将输出以下内容:
iex(18)> d1 = Date.from_erl! {2016, 12, 29}
iex(19)> d2 = Date.from_erl! {2017, 1, 19}
iex(24)> Recovery.phases(d1, d2, 30, 5)
[%Phase{day: ~D[2017-01-01], weight: 45},
 %Phase{day: ~D[2017-01-02], weight: 50},
 %Phase{day: ~D[2017-01-03], weight: 55},
 %Phase{day: ~D[2017-01-04], weight: 60},
 %Phase{day: ~D[2017-01-05], weight: 65},
 %Phase{day: ~D[2017-01-06], weight: 70},
 %Phase{day: ~D[2017-01-07], weight: 75},
 %Phase{day: ~D[2017-01-08], weight: 80},
 %Phase{day: ~D[2017-01-09], weight: 85},
 %Phase{day: ~D[2017-01-10], weight: 90},
 %Phase{day: ~D[2017-01-11], weight: 95},
 %Phase{day: ~D[2017-01-12], weight: 100},
 %Phase{day: ~D[2017-01-13], weight: 105},
 %Phase{day: ~D[2017-01-14], weight: 110},
 %Phase{day: ~D[2017-01-15], weight: 115},
 %Phase{day: ~D[2017-01-16], weight: 120},
 %Phase{day: ~D[2017-01-17], weight: 125},
 %Phase{day: ~D[2017-01-18], weight: 130},
 %Phase{day: ~D[2017-01-19], weight: 135},
 %Phase{day: ~D[2016-12-29], weight: 30},
 %Phase{day: ~D[2016-12-30], weight: 35},
 %Phase{day: ~D[2016-12-31], weight: 40}]

最佳答案

似乎您正在使用的库中的日期结构看起来像这样:%Date{day: 25, month: 12, year: 2014}。在Elixir中,按字段的字母顺序通过结构的内容对结构进行比较。在这种情况下,最重要的是day,然后是monthyear-与您要查找的相反。

您可以尝试将Enum.sort_by(values, &(&1.day))更改为Enum.sort_by(values, &(Date.to_erl(&1.day)))。这会将%Date{}结构转换为应该按预期排序的Erlang元组。

关于Elixir中的日期排序列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41655852/

相关文章:

javascript - 如何使javascript中的排序函数表现得像mysql order by

C 如何将一个选项卡排序为多个选项卡

python - 如何使用 datetime 获取某一天一周内的所有日期?

swift - 是否可以扩展 Calendar.Identifier 来创建自定义日历?

r - 根据多个正则表达式子字符串对变量进行排序

linux - 根据第一列按数字排序

mysql - 在 MySQL 中使用 INTERVAL 和 CURDATE

SQL 日期公式

android - 从日历中减去天数

Java日历算术问题