2009-07-04 8 views

Respuesta

57

A continuación, yourDate representa su entrada NSDate; nextDate representa el día siguiente.

// 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

Hola, Sí, este código funciona Muchas gracias, ¿Tienes alguna idea sobre cómo obtener el día anterior (ayer)? – Jai

+0

Cambiando [offsetComponents setDay: 1] para setDay: -1 resulta en restar un día en lugar de agregar – rpetrich

+0

Esto también funciona cuando la próxima fecha se mueve de horario de verano a horario estándar. Intente pasar de 2011-11-06. Gracias @unforgiven. – johnnieb

2

// Añadir el código de abajo a init método o viewDidLoad

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

// Añadir este código donde quieres recuperar fechas anteriores o siguientes

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

Cave: la adición repetida de SecondPerDay (24 * 60 * 60) con addTimeInterval a un NSDate se realiza mientras se observa el horario de verano. Agregar 24 horas en un día cuando ingresa o sale del horario de ahorro de luz diurna desvía la hora del día en +/- 1 hora. –

28

¿qué pasa con estos métodos?

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

** Mucho ** mejor solución que las más votadas en este tema –

3

supongo que este método funciona bien para mí.

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

Esto puede causar problemas al atravesar los límites del día al contabilizar DST. – Kyle

+2

Ídem, Esto puede dar resultados incorrectos cuando hay un cambio de horario de verano en el rango de fechas. – progrmr

+0

No hará lo que espera si hay un segundo intercalar. –

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

Mucho más forma más fácil ..

+19

Esto puede dar resultados incorrectos cuando hay un cambio de horario de verano en el rango de fechas. – progrmr

+4

También cuando hay un segundo intercalar. –

+0

Lo suficiente para mí –

Cuestiones relacionadas