2009-07-04 12 views

Répondre

57

Dans ce qui suit, yourDate représente votre entrée NSDate; nextDate représente le jour suivant.

// start by retrieving day, weekday, month and year components for yourDate 
    NSCalendar *gregorian = [[NSCalendar alloc] initWithCalendarIdentifier:NSGregorianCalendar]; 
    NSDateComponents *todayComponents = [gregorian components:(NSDayCalendarUnit | NSMonthCalendarUnit | NSYearCalendarUnit) fromDate:yourDate]; 
    NSInteger theDay = [todayComponents day]; 
    NSInteger theMonth = [todayComponents month]; 
    NSInteger theYear = [todayComponents year]; 

    // now build a NSDate object for yourDate using these components 
    NSDateComponents *components = [[NSDateComponents alloc] init]; 
    [components setDay:theDay]; 
    [components setMonth:theMonth]; 
    [components setYear:theYear]; 
    NSDate *thisDate = [gregorian dateFromComponents:components]; 
    [components release]; 

    // now build a NSDate object for the next day 
    NSDateComponents *offsetComponents = [[NSDateComponents alloc] init]; 
    [offsetComponents setDay:1]; 
    NSDate *nextDate = [gregorian dateByAddingComponents:offsetComponents toDate:thisDate options:0]; 
    [offsetComponents release]; 
    [gregorian release]; 
+0

Salut, Ouais ce code fonctionne Merci beaucoup, Avez-vous une idée sur la façon d'obtenir le jour précédent (hier)? – Jai

+0

La modification de [offsetComponents setDay: 1] à setDay: -1 entraîne la soustraction d'un jour au lieu de l'ajout – rpetrich

+0

Cela fonctionne également lorsque la date suivante passe de l'heure d'été à l'heure standard. Essayez de partir du 2011-11-06. Merci @unforgiven. – johnnieb

2

// Ajoutez le code ci-dessous init méthode ou viewDidLoad

[[NSUserDefaults standardUserDefaults] setObject:[NSDate date] forKey:@"Date"]; 

// Ajoutez ce code où vous voulez récupérer les dates suivantes ou précédentes

NSDate *tomorrow = [[NSUserDefaults standardUserDefaults] valueForKey:@"Date"]; 
NSTimeInterval secondsPerDay = 24 * 60 * 60;  
NSDate *date = [tomorrow addTimeInterval:secondsPerDay]; //Change NSDate *date = [tomorrow addTimeInterval:-secondsPerDay]; for yesterday 
tomorrow = date; 
[self setDate:tomorrow]; 
dateTextField.text = [self getDate];   
[[NSUserDefaults standardUserDefaults] setObject:tomorrow forKey:@"Date"]; 
+1

Grotte: L'ajout répétitif de secondsPerDay (24 * 60 * 60) avec addTimeInterval à un NSDate est effectué en respectant l'heure d'été. L'ajout de 24 heures sur un jour lorsque vous entrez ou quittez l'heure d'été réduit l'heure de +/- 1 heure. –

28

Qu'en est ces méthodes?

http://www.drobnik.com/touch/2009/05/adding-days-to-nsdate/

NSDate *now = [NSDate date]; 
int daysToAdd = 50; // or 60 :-) 

// set up date components 
NSDateComponents *components = [[[NSDateComponents alloc] init] autorelease]; 
[components setDay:daysToAdd]; 

// create a calendar 
NSCalendar *gregorian = [[[NSCalendar alloc] initWithCalendarIdentifier:NSGregorianCalendar] autorelease]; 

NSDate *newDate2 = [gregorian dateByAddingComponents:components toDate:now options:0]; 
NSLog(@"Clean: %@", newDate2); 
+1

** Beaucoup ** meilleure solution que la plus upvoted dans ce sujet –

3

Je suppose que cette méthode fonctionne très bien pour moi.

NSString *zajtra = [[NSDate date] dateByAddingTimeInterval:86400]; 
+1

Cela peut causer des problèmes lors de la traversée des limites de jour lors de la prise en compte de l'heure d'été. – Kyle

+2

Idem, Cela peut donner des résultats incorrects lorsqu'il y a un changement de l'heure d'été dans la plage de dates. – progrmr

+0

Ne fera pas ce que vous attendez s'il y a une seconde intercalaire. –

34
NSDate *tomorrow = [NSDate dateWithTimeInterval:(24*60*60) sinceDate:[NSDate date]]; 

façon beaucoup plus facile ..

+19

Cela peut donner des résultats incorrects lorsque l'heure d'été est modifiée dans la plage de dates. – progrmr

+4

Aussi quand il y a une seconde intercalaire. –

+0

Bonne assez pour moi –