NStimeInterval to HH:mm:ss?
NST 타임이 있는 경우200.0으로 설정된 인터벌에서 00:03:20으로 변환할 방법이 있을까요? NSDate를 초기화한 다음 HH:mm:ss를 사용하여 NSDateFormatter를 사용할 수 있다고 생각했습니다.제 질문은 이것을 할 수 있는 빠른 방법이 있나요 아니면 제가 직접 번호를 분해해서 사용해야 하나요?[NSString stringWithFormat: %02d:%02d:%02d, myHour, myMin, mySec]
?
사용할 필요 없음NSDateFormatter
분열과 모듈로가 아닌 다른 것도 가능합니다.NSTimeInterval
초를 포함한 두 배일 뿐입니다
스위프트
func stringFromTimeInterval(interval: NSTimeInterval) -> String {
let interval = Int(interval)
let seconds = interval % 60
let minutes = (interval / 60) % 60
let hours = (interval / 3600)
return String(format: "%02d:%02d:%02d", hours, minutes, seconds)
}
목적-C
- (NSString *)stringFromTimeInterval:(NSTimeInterval)interval {
NSInteger ti = (NSInteger)interval;
NSInteger seconds = ti % 60;
NSInteger minutes = (ti / 60) % 60;
NSInteger hours = (ti / 3600);
return [NSString stringWithFormat:@"%02ld:%02ld:%02ld", (long)hours, (long)minutes, (long)seconds];
}
iOS 8에서는 를 사용합니다.
NSDateComponentsFormatter *dateComponentsFormatter = [[NSDateComponentsFormatter alloc] init];
NSLog(@"%@", [dateComponentsFormatter stringFromTimeInterval:200.0]);
출력 "3:20".
NSDateComponentsFormatter *dateComponentsFormatter = [[NSDateComponentsFormatter alloc] init];
dateComponentsFormatter.zeroFormattingBehavior = NSDateComponentsFormatterZeroFormattingBehaviorPad;
dateComponentsFormatter.allowedUnits = (NSCalendarUnitHour | NSCalendarUnitMinute | NSCalendarUnitSecond);
NSLog(@"%@", [dateComponentsFormatter stringFromTimeInterval:200.0]);
출력 "0:03:20".
스위프트 3 버전 on myway133의 답변:
import Foundation
func format(_ duration: TimeInterval) -> String {
let formatter = DateComponentsFormatter()
formatter.zeroFormattingBehavior = .pad
formatter.allowedUnits = [.minute, .second]
if duration >= 3600 {
formatter.allowedUnits.insert(.hour)
}
return formatter.string(from: duration)!
}
print(format(12)) // 0:12
print(format(65)) // 1:05
print(format(1750)) // 29:10
print(format(3890)) // 1:04:50
print(format(45720)) // 12:42:00
코드 라인이 몇 개 더 있지만 NSDateComponents를 사용하면 더 정확한 값을 얻을 수 있을 것 같습니다.
- (NSString *)getTimeRepresentationFromDate:(NSDate *)iDate withTimeInterval:(NSTimeInterval)iTimeInterval {
NSString *aReturnValue = nil;
NSDate *aNewDate = [iDate dateByAddingTimeInterval:iTimeInterval];
unsigned int theUnits = NSHourCalendarUnit | NSMinuteCalendarUnit | NSSecondCalendarUnit;
NSCalendar *aCalender = [NSCalendar currentCalendar];
NSDateComponents *aDateComponents = [aCalender components:theUnits fromDate:iDate toDate:aNewDate options:0];
aReturnValue = [NSString stringWithFormat:@"%d:%d:%d", [aDateComponents hour], [aDateComponents minute], [aDateComponents second]];
return aReturnValue;
}
스위프트 2에서는 iOS 8+.이것은 우리가 필요할 때만 시간을 보여주는 것을 보장합니다.
func format(duration: NSTimeInterval) -> String {
let formatter = NSDateComponentsFormatter()
formatter.zeroFormattingBehavior = .Pad
if duration >= 3600 {
formatter.allowedUnits = [.Hour, .Minute, .Second]
} else {
formatter.allowedUnits = [.Minute, .Second]
}
return formatter.stringFromTimeInterval(duration) ?? ""
}
그래서 당신은.
print(format(12)) // 0:12
print(format(65)) // 1:05
print(format(1750)) // 29:10
print(format(3890)) // 1:04:50
print(format(45720)) // 12:42:00
스위프트 4
DateComponentsFormatter().string(from: <# TimeInterval #>)
ex:
DateComponentsFormatter().string(from: 59.0)
NSTimeInterval ti = 3667;
double hours = floor(ti / 60 / 60);
double minutes = floor((ti - (hours * 60 * 60)) / 60);
double seconds = floor(ti - (hours * 60 * 60) - (minutes * 60));
Matthias Bauch의 제안을 "확장"하기 위해, 스위프트에서 나는 이것을 NSTime의 계산된 속성으로 만들 것입니다.간격:
extension NSTimeInterval {
var stringValue: String {
let interval = Int(self)
let seconds = interval % 60
let minutes = (interval / 60) % 60
let hours = (interval / 3600)
return String(format: "%02d:%02d:%02d", hours, minutes, seconds)
}
}
이것의 장점은 그것이 에 붙어 있다는 것입니다.NSTimeInterval
보기 컨트롤러나 해당 기능을 어디에 두더라도 입력할 수 없습니다.사용하려면 다음과 같은 작업을 수행합니다.
let timeInterval = NSDate().timeIntervalSinceDate(start)
self.elapsedTimeLabel.text = timeInterval.stringValue
@onmyway133의 답변을 토대로 스위프트 4 버전을 소개합니다.
func format(duration: TimeInterval) -> String {
let formatter = DateComponentsFormatter()
formatter.zeroFormattingBehavior = .pad
if duration >= 3600 {
formatter.allowedUnits = [.hour, .minute, .second];
} else {
formatter.allowedUnits = [.minute, .second];
}
return formatter.string(from: duration) ?? "";
}
Apple 문서에서 직접: h 파일에서:
@property(strong,nonatomic)NSDateComponentsFormatter *timerFormatter;
m열로
@synthesize timerFormatter;
- (void)viewDidLoad {
[super viewDidLoad];
NSDateComponentsFormatter *timerFormatter = [[NSDateComponentsFormatter alloc] init];
timerFormatter.unitsStyle = NSDateComponentsFormatterUnitsStylePositional;
//10:59 Positional THIS ONE DOES NOT SEEM TO WORK iOS<9 WHEN <1Minute JUST SHOWS 01, 10m 59s Abbreviated, 10min 59sec Short, 10minutes 59seconds Full ...
timerFormatter.allowedUnits = NSCalendarUnitHour|NSCalendarUnitMinute|NSCalendarUnitSecond;
}
NSTime을 변환해야 하는 곳에서간격시간간격:mm:ss 문자열, 다음 작업 수행:
NSString *txt=[timerFormatter stringFromTimeInterval:timeInterval];
아마도, 타이머 분율이 제한되어야 할 것 같습니다.Matthias의 코드가 몇 초 만에 그 문제를 만들고 있었기 때문에, 저는 Matthias의 코드에서 약간 변형된 다음을 사용합니다.
- (NSString *)stringFromTimeInterval:(NSTimeInterval)interval {
int ti = (int) ceil(interval);
int seconds = ti % 60;
int minutes = (ti / 60) % 60;
int hours = (ti / 3600);
return [NSString stringWithFormat:@"%02d:%02d:%02d",hours, minutes, seconds];
}
목표 C 버전 on myway133의 답변
- (NSString*) formatTimeInterval:(NSTimeInterval) timeInterval {
NSDateComponentsFormatter *formatter = [[NSDateComponentsFormatter alloc] init];
formatter.zeroFormattingBehavior = NSDateComponentsFormatterZeroFormattingBehaviorPad;
if (timeInterval > 3600) {
formatter.allowedUnits = NSCalendarUnitHour | NSCalendarUnitMinute | NSCalendarUnitSecond;
} else {
formatter.allowedUnits = NSCalendarUnitMinute | NSCalendarUnitSecond;
}
return [formatter stringFromTimeInterval:timeInterval];
}
언급URL : https://stackoverflow.com/questions/4933075/nstimeinterval-to-hhmmss
'programing' 카테고리의 다른 글
대체 for-loop 구문 (0) | 2023.09.19 |
---|---|
스택 오버플로로 인해 세그먼트화 오류가 아닌 다른 문제가 발생할 수 있습니까? (0) | 2023.09.19 |
파이썬에서 "(1,) == 1"의 의미는 무엇입니까? (0) | 2023.09.19 |
iPhone vs iPad/Browser HTML5 인라인 비디오 (0) | 2023.09.19 |
element.remove를 호출할 때 $destroy가 트리거되지 않는 이유는 무엇입니까? (0) | 2023.09.19 |