从sqlite中获取日期并显示在UILabel视图中



嗨,在我的应用程序中,我在dd-mm-yy格式的本地数据库中有日期。现在我想从我的本地数据库获取月相关的日期,例如jan意味着我想从我的本地数据库获取所有jan日期。我想分别获得日期dd分别月和年分别存储到字符串显示在我的UILabel。抓取不能正常工作,请帮助我。

在本地数据库中,我的日期就像我打印数组时显示的那样array11

"29-7-2014",
"15-8-2014",
"19-7-2014",
"20-7-2014",
"20-9-2014",
"18-9-2014",
"20-9-2014",

MY code database fetch code.

-(void)GETVALUE{
   [self openDB1];
   array11 =[[NSMutableArray alloc]init];
   array1 =[[NSMutableArray alloc]init];
   NSString *sql =[NSString stringWithFormat:@"SELECT * FROM cl"];
sqlite3_stmt *statement;
 if (sqlite3_prepare_v2(db1, [sql UTF8String], -1, &statement, nil) == SQLITE_OK) {
    while (sqlite3_step(statement)== SQLITE_ROW) {
         char *field2 = (char *)sqlite3_column_text(statement, 1);
         NSString *field2Str =[[NSString alloc]initWithUTF8String:field2];
         char *field1 = (char *)sqlite3_column_text(statement, 2);
         NSString *field1Str =[[NSString alloc]initWithUTF8String:field1];
         NSString *str = [[NSString alloc]initWithFormat:@"%@",field1Str];
         NSString *str1 = [[NSString alloc]initWithFormat:@"%@",field2Str];
         [array11 addObject:str];
         [array1 addObject:str1];

        }
    }
 }

我的比较代码。

  mont = @"7";
  yr =@"2014";
  NSInteger mon = [mont intValue];
  NSInteger yea = [yr intValue];
  [self GETVALUE];
   NSCalendar *gregCalendar = [[NSCalendar alloc] initWithCalendarIdentifier:NSGregorianCalendar];
   NSDateComponents *dateComponent = [gregCalendar components:NSYearCalendarUnit | NSMonthCalendarUnit | NSDayCalendarUnit | NSHourCalendarUnit | NSMinuteCalendarUnit fromDate:[NSDate date]];
     NSArray *dobArray = array1;
     NSArray *messagesArray = array11;
     NSLog(@"%@",dobArray);
   for (NSString *dobStr in dobArray) {
       NSArray *components = [dobStr componentsSeparatedByString:@"-"];
    if(components.count>3) {
        NSInteger aDay = [[components objectAtIndex:0] integerValue];
        NSInteger aMonth = [[components objectAtIndex:1] integerValue];
        NSInteger aYear = [[components objectAtIndex:2] integerValue];
        if(aMonth == mon && aYear == yea) {
            [dateComponent setDay:aDay];
            [dateComponent setMonth:aMonth];
            [dateComponent setYear:aYear];
            UIDatePicker *dp = [[UIDatePicker alloc] init];
            [dp setDate:[gregCalendar dateFromComponents: dateComponent]];
            //inStr = [NSString stringWithFormat:@"%@",dp];
           // NSLog(@"%@ss", inStr);
        }
    }
}

我已经使用了上面的代码,但它不工作,它不检查,请告诉我如何实现这个

谢谢。

将下面的代码替换为for循环

 for (int index = 0 ; index <dobArray.count ; index++) {
   NSArray *components = [dobStr componentsSeparatedByString:@"-"];
   if(components.count>3) {
         NSString *components = [dobArray objectAtIndex:index];
        NSDateFormatter *dateFormet = [[NSDateFormatter alloc]init];
        [dateFormet setDateFormat:@"dd-MM-yyyy"];
        NSDate *date = [dateFormet dateFromString:components];
        [dp setDate:date];
   }
 }

,现在试试。它会工作

您的代码非常冗余,并且包含许多奇怪的花朵,例如

mont = @"7";
NSInteger mon = [mont intValue];

第一行是不相关的,你可以直接写7intValue返回一个int,而integerValue返回一个NSInteger

NSString *str1 = [[NSString alloc]initWithFormat:@"%@",field2Str];

你可以直接使用field2Str

你的变量名选择得很糟糕——这就是你感到困惑的原因,就像你代码的每个外部读者一样。

array1(由于某种原因被重命名为dobArray)中存储了来自数据库的str1 s,也就是field2Str。您的比较代码容易出现潜在的错误,但它应该可以处理您发布的数据。然而,如果你点击了日期,你是在分配一个日期选择器,并没有对它做任何事情。似乎你应该有一个日期选择器初始化,例如通过故事板,然后设置该选择器的date

最新更新