java - 在 Scala 中,如何在开始日期和结束日期之间创建一列包含每月日期的日期数组?
问题描述
在 Spark Scala 中,我正在尝试创建一个列,其中包含开始日期和结束日期(含)之间的每月日期数组。
例如,如果我们有 2018-02-07 和 2018-04-28,则数组应包含 [2018-02-01, 2018-03-01, 2018-04-01]。
除了每月版本,我还想创建一个季度版本,即 [2018-1, 2018-2]。
输入数据示例:
id startDate endDate
1_1 2018-02-07 2018-04-28
1_2 2018-05-06 2018-05-31
2_1 2017-04-13 2017-04-14
预期(每月)产出 1:
id startDate endDate dateRange
1_1 2018-02-07 2018-04-28 [2018-02-01, 2018-03-01, 2018-04-01]
1_1 2018-05-06 2018-05-31 [2018-05-01]
2_1 2017-04-13 2017-04-14 [2017-04-01]
最终预期(每月)产出 2:
id Date
1_1 2018-02-01
1_1 2018-03-01
1_1 2018-04-01
1_2 2018-05-01
2_1 2017-04-01
我有 spark 2.1.0.167、Scala 2.10.6 和 JavaHotSpot 1.8.0_172。
我已经尝试在此处对类似(日级)问题实施几个答案,但我正在努力让每月/每季度的版本正常工作。
下面从 start 和 endDate 创建一个数组并将其分解。但是,我需要展开一个包含其间所有每月(每季度)日期的列。
val df1 = df.select($"id", $"startDate", $"endDate").
// This just creates an array of start and end Date
withColumn("start_end_array"), array($"startDate", $"endDate").
withColumn("start_end_array"), explode($"start_end_array"))
感谢您提供任何线索。
解决方案
case class MyData(id: String, startDate: String, endDate: String, list: List[String])
val inputData = Seq(("1_1", "2018-02-07", "2018-04-28"), ("1_2", "2018-05-06", "2018-05-31"), ("2_2", "2017-04-13", "2017-04-14"))
inputData.map(x => {
import java.time.temporal._
import java.time._
val startDate = LocalDate.parse(x._2)
val endDate = LocalDate.parse(x._3)
val diff = ChronoUnit.MONTHS.between(startDate, endDate)
var result = List[String]();
for (index <- 0 to diff.toInt) {
result = (startDate.getYear + "-" + (startDate.getMonth.getValue + index) + "-01") :: result
}
new MyData(x._1, x._2, x._3, result)
}).foreach(println)
推荐阅读
- ios - 内部有模型时如何在可编码中使用init方法?
- airflow - Apache Airflow 环境设置
- javascript - 在 Java 中合并两个对象列表以创建带有 Jackson 的 Json
- amazon-web-services - Aws Sagemaker 调用端点调用和 csv
- python - 为什么大型 xml 解析无法按预期工作?
- python - Python msfrpc 与 python2 一起使用,使用 python 3 引发身份验证错误
- python - Numpy 2d 数组 - 在没有 for 循环的情况下选择多个元素
- jms - 由于未提交发送事务,JMS 无法接收
- machine-learning - ML 从头开始创建 word2vec
- c - 我可以用什么来等待所有线程被创建?