我需要按时间和日期对即将发生的事件对表格进行排序。我需要顶部最近的未来日期字符串,由以下事件降序排列。但是我想将过去的事件拖放到数组/表的底部,在那里我将隐藏日期和时间,以便显示历史记录。
它是一个结构数组,如果这有所作为
例如:
活动3 - 14:15
活动4 - 15:00
活动5 - 18:03
事件 1 -
事件2 -
以下工作来排序我的数组,我只想将过去的日期放在底部
newArray = oldArray.sorted(by: {Date(timeIntervalSinceNow: $0.eventTime < Date(timeIntervalSinceNow: $1.eventTime})
解决方案 A:排序、拆分和合并
let now = Date()
let sortedArray = myArray.sorted(by: { $0.startTime < $1.startTime })
var finalArray = sortedArray
if let index = sortedArray.index(where: { $0.startTime > now }) {
if index > 0 {
finalArray = Array(sortedArray[index ..< sortedArray.endIndex] + sortedArray[sortedArray.startIndex ... index - 1])
}
}
解决方案 B(更快(:按谓词排序
let now = Date()
let newArray = myArray.sorted(by: {
if $0.startTime > now {
if $1.startTime > now {
return $0.startTime < $1.startTime
} else {
return true
}
} else {
if $1.startTime > now {
return false
} else {
return $0.startTime < $1.startTime
}
}
})
作为临时修复,我已经这样做了,我确信有一种更优雅的方法,但它可能会帮助其他人,直到出现更好的解决方案。
let allStartToFin = myArrat.sorted(by: {Date(timeIntervalSinceNow:($0.startTime)!).timeIntervalSinceNow < Date(timeIntervalSinceNow:($1.startTime)!).timeIntervalSinceNow})
var correctOrder = [Object]()
var past = [Object]()
for item in 0...(allStartToFin.count - 1) {
if (Date(timeIntervalSince1970: TimeInterval((allStartToFin[item].startTime)!))) > Date() {
correctOrder.append(allStartToFin[item])
} else {
past.append(allStartToFin[item])
}
if item == (allStartToFin.count - 1) {
correctOrder = correctOrder + past
self.finalArray = correctOrder
self.tableView.reloadData()
}
}