Frage NSTimeInterval zu HH: mm: ss?


Wenn ich einen NSTimeInterval habe, der auf 200.0 gesetzt ist, gibt es eine Möglichkeit, das in 00:03:20 zu konvertieren, dachte ich, ich könnte ein NSDate damit initialisieren und dann NSDateFormatter mit HH: mm: ss verwenden. Meine Frage ist, gibt es einen schnellen Weg, dies zu tun oder muss ich die Nummer selbst aufbrechen und verwenden [NSString stringWithFormat: %02d:%02d:%02d, myHour, myMin, mySec]?


74
2018-02-08 12:36


Ursprung


Antworten:


Keine Notwendigkeit zu verwenden NSDateFormatter oder irgendetwas anderes als Division und Modulo. NSTimeInterval ist nur ein Doppel mit Sekunden.

Schnell

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)
}

Ziel 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];
}

189
2018-02-08 12:42



Auf iOS 8 verwenden NSDateComponentsFormatter.

NSDateComponentsFormatter *dateComponentsFormatter = [[NSDateComponentsFormatter alloc] init];
NSLog(@"%@", [dateComponentsFormatter stringFromTimeInterval:200.0]);

gibt "3:20" aus.

NSDateComponentsFormatter *dateComponentsFormatter = [[NSDateComponentsFormatter alloc] init];
dateComponentsFormatter.zeroFormattingBehavior = NSDateComponentsFormatterZeroFormattingBehaviorPad;
dateComponentsFormatter.allowedUnits = (NSCalendarUnitHour | NSCalendarUnitMinute | NSCalendarUnitSecond);
NSLog(@"%@", [dateComponentsFormatter stringFromTimeInterval:200.0]);

gibt "0:03:20" aus.


88
2017-10-02 14:38



Schnell 3 Version von onmyway133Antwort:

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

14
2017-10-29 16:36



Einige zusätzliche Codezeilen, aber ich denke, dass die Verwendung von NSDateComponents einen präziseren Wert ergibt.

- (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;
}

10
2017-11-13 10:27



Im Schnell 2, iOS 8+. Dies stellt sicher, dass wir nur Stunden zeigen, wenn es notwendig ist

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) ?? ""
}

Also hast du

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

6
2017-08-30 13:04



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));

5
2017-11-06 00:20



Um den Vorschlag von Matthias Bauch zu "erweitern", würde ich dies in Swift zu einer berechneten Eigenschaft von NSTimeInterval machen:

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)
  }
}

Der Vorteil davon ist, dass es an die NSTimeInterval Geben Sie nicht Ihren View Controller oder sonst wo ein. Sie würden etwas wie:

let timeInterval = NSDate().timeIntervalSinceDate(start)        
self.elapsedTimeLabel.text = timeInterval.stringValue

4
2017-11-25 01:41



Basierend auf der Antwort von @ onmyway133 ist hier die Swift 4 Version:

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) ?? "";
}

0
2018-02-05 07:09



direkt aus apple docs: in h Datei:

 @property(strong,nonatomic)NSDateComponentsFormatter *timerFormatter;

in m Datei

@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;
}

Wo auch immer Sie Ihren NSTimeInterval timeInterval in hh: mm: ss String konvertieren müssen, tun Sie dies:

NSString *txt=[timerFormatter stringFromTimeInterval:timeInterval];

0
2018-03-06 20:46



Ich denke, der Timer-Anteil sollte überschritten werden. Da Matthias 'Code dieses Problem in Sekunden erzeugte, benutze ich das leicht modifizierte von dem von 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];
    }

0
2018-03-08 04:29