저는 Swift를 처음 사용하고 스케줄러를 시도하고 있습니다. 시작 시간을 선택했고 시작 시간에 5 분 (또는 그 배수)을 추가하고 UILabel에 표시해야합니까?
@IBAction func timePickerClicked(sender: UIDatePicker) {
var dateFormatter = NSDateFormatter()
dateFormatter.timeStyle = NSDateFormatterStyle.ShortStyle
var dateStr = dateFormatter.stringFromDate(startTime.date)
let sttime = dateStr
startTimeDisplay.text = dateStr
}
// How to advance time by 5 minutes for each section based on the start time selected and display time
// section 1 = start time + 5
// section 2 = start time + 10*
답변
두 가지 접근 방식 :
-
사용
Calendar
하고date(byAdding:to:wrappingComponents:)
. 예 : Swift 3 이상에서 :let calendar = Calendar.current let date = calendar.date(byAdding: .minute, value: 5, to: startDate)
-
+
연산자 (참조+(_:_:)
)를 사용 하여 aTimeInterval
(예 : 특정 시간 )를 추가 하십시오 . 예를 들어 5 분을 추가하려면 다음을 수행 할 수 있습니다.let date = startDate + 5 * 60
(여기에서 순서는 구체적입니다. 왼쪽의 날짜
+
와 오른쪽의 초입니다.)원하는
addingTimeInterval
경우를 사용할 수도 있습니다 .let date = startDate.addingTimeInterval(5 * 60)
결론적으로 +
/ addingTimeInterval
는 간단한 시나리오에서 가장 쉽지만 더 큰 단위 (예 : 일, 월 등)를 추가하려는 경우 일광 절약을 위해 조정되지만 addingTimeInterval
그렇지 않은 경우 캘린더 계산을 사용하는 것이 좋습니다. .
답변
캘린더의 방법을 사용할 수 있습니다.
func date(byAdding component: Calendar.Component, value: Int, to date: Date, wrappingComponents: Bool = default) -> Date?
어떤 추가 Calendar.Component
어느를 Date
. 날짜 확장을 만들어의 날짜에 x 분을 추가 할 수 있습니다 UIDatePicker
.
Xcode 8 및 Xcode 9 • Swift 3.0 및 Swift 4.0
extension Date {
func adding(minutes: Int) -> Date {
return Calendar.current.date(byAdding: .minute, value: minutes, to: self)!
}
}
그런 다음 확장 메서드를 사용하여 발신자 (UIDatePicker)에게 분을 추가 할 수 있습니다.
let section1 = sender.date.adding(minutes: 5)
let section2 = sender.date.adding(minutes: 10)
놀이터 테스트 :
Date().adding(minutes: 10) // "Jun 14, 2016, 5:31 PM"
답변
스위프트 4 :
// 현재까지 5 분 추가
let date = startDate.addingTimeInterval(TimeInterval(5.0 * 60.0))
// 날짜에서 5 분 빼기
let date = startDate.addingTimeInterval(TimeInterval(-5.0 * 60.0))
Swift 5.1 :
// subtract 5 minutes from date
transportationFromDate.addTimeInterval(TimeInterval(-5.0 * 60.0))
답변
를 사용하여 날짜 산술을 수행 할 수 있습니다 NSDateComponents
. 예를 들면 :
import Foundation
let comps = NSDateComponents()
comps.minute = 5
let cal = NSCalendar.currentCalendar()
let r = cal.dateByAddingComponents(comps, toDate: NSDate(), options: nil)
놀이터에서 시도해 보면 보이는 것입니다.
답변
NSDate.init
와 함께 timeIntervalSinceNow
:
예 :
let dateAfterMin = NSDate.init(timeIntervalSinceNow: (minutes * 60.0))
답변
이 작은 확장을 저장하십시오.
extension Int {
var seconds: Int {
return self
}
var minutes: Int {
return self.seconds * 60
}
var hours: Int {
return self.minutes * 60
}
var days: Int {
return self.hours * 24
}
var weeks: Int {
return self.days * 7
}
var months: Int {
return self.weeks * 4
}
var years: Int {
return self.months * 12
}
}
그런 다음 다음과 같이 직관적으로 사용하십시오.
let threeDaysLater = TimeInterval(3.days)
date.addingTimeInterval(threeDaysLater)
답변
신속한 4 또는 5에서 사용할 수 있습니다.
let date = Date()
let dateFormatter = DateFormatter()
dateFormatter.dateFormat = "yyyy-MM-dd H:mm:ss"
let current_date_time = dateFormatter.string(from: date)
print("before add time-->",current_date_time)
//adding 5 miniuts
let addminutes = date.addingTimeInterval(5*60)
dateFormatter.dateFormat = "yyyy-MM-dd H:mm:ss"
let after_add_time = dateFormatter.string(from: addminutes)
print("after add time-->",after_add_time)
산출:
before add time--> 2020-02-18 10:38:15
after add time--> 2020-02-18 10:43:15