嗨,在我的应用程序中,我在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];
第一行是不相关的,你可以直接写7
。intValue
返回一个int
,而integerValue
返回一个NSInteger
。
或
NSString *str1 = [[NSString alloc]initWithFormat:@"%@",field2Str];
你可以直接使用field2Str
。
你的变量名选择得很糟糕——这就是你感到困惑的原因,就像你代码的每个外部读者一样。
在array1
(由于某种原因被重命名为dobArray
)中存储了来自数据库的str1
s,也就是field2Str
。您的比较代码容易出现潜在的错误,但它应该可以处理您发布的数据。然而,如果你点击了日期,你是在分配一个日期选择器,并没有对它做任何事情。似乎你应该有一个日期选择器初始化,例如通过故事板,然后设置该选择器的date
。