0

私は非常に基本的な問題を扱っています。比較する必要がある2つの辞書キーがありますが、比較すると正しい答えが得られず、どういうわけかロジックの作成に失敗しています。

だから私はこれを辞書のplist配列とサーバーからのjson配列に持っています。イベントがplistに存在する場合はそれらを比較し、別のことをしない場合は特定のことを行います。

問題:
私のロジックによると、plist の 2 つのイベントがサーバーからの他の 2 つのイベントと等しい場合、サーバーからの辞書ごとにロジックを出力する必要がある場合、この場合は合計 2 回ですが、私のコードでは 4 回出力されます. 基本的に毎回条件を満たしています。

NSLOG:

evreka find the id
evreka find the id
evreka find the id
evreka find the id

ソース: plist で。

createList (
        {
        "end_date" = "2013-07-24";
        ends = "13:07:00";
        "event_id" = 173;
        "event_name" = Static;
        location = Asdad;
        "root_folder" = "dadapof@gmail.com";
        "start_date" = "2013-07-24";
        starts = "13:07:00";
        "user_id" = 13;
    },
        {
        "end_date" = "2013-07-25";
        ends = "13:08:00";
        "event_id" = 174;
        "event_name" = "Event Delete";
        location = Asdsad;
        "root_folder" = "dadapof@gmail.com";
        "start_date" = "2013-07-25";
        starts = "13:08:00";
        "user_id" = 13;
    }
)

これはサーバーから来ています

responseobj (
        {
        "end_date" = "2013-07-24";
        ends = "13:07:00";
        "event_id" = 173;
        "event_name" = Static;
        location = Asdad;
        "root_folder" = "dadapof@gmail.com";
        "start_date" = "2013-07-24";
        starts = "13:07:00";
        "user_id" = 13;
    },
        {
        "end_date" = "2013-07-25";
        ends = "13:08:00";
        "event_id" = 174;
        "event_name" = "Event Delete";
        location = Asdsad;
        "root_folder" = "dadapof@gmail.com";
        "start_date" = "2013-07-25";
        starts = "13:08:00";
        "user_id" = 13;
    }
)

コード:

比較コード;

if ([[NSFileManager defaultManager] fileExistsAtPath:dataPath]){
        createList= [NSMutableArray arrayWithContentsOfFile:dataPath];
        NSLog(@"createList %@",createList);
        NSLog(@"responseobj %@",responseObj);


        //compare plist and response object
        for (int i=0; i<[responseObj count]; i++) {
            NSDictionary *dataDict = [responseObj objectAtIndex:i];

            NSString *event_name =[dataDict objectForKey:@"event_name"];
            //NSString *event_id =[dataDict objectForKey:@"event_id"];

            BOOL eventExistInPlist=NO;


            for (int j=0; j<[createList count]; j++) {
                NSDictionary *createDict = [createList objectAtIndex:i];

                //NSString *create_id =[createDict objectForKey:@"event_id"];
                NSNumber *create_id =[createDict objectForKey:@"event_id"];

                if ([[dataDict objectForKey:@"event_id"] isEqual:[createDict objectForKey:@"event_id"]]) {
               // if (create_id==event_id) {
                    NSLog(@"evreka find the id"); 

私が試したこと: string(isEqualtoString)、numbers(==)、isEqual: method として比較しようとしましたが、すべて失敗しました。

私は何を間違っていますか?

4

2 に答える 2

3

 NSDictionary *createDict = [createList objectAtIndex:i];
                                                      ^----- HERE

間違ったインデックスを使用しています。内側のループのj代わりに使用する必要があります。i

于 2013-07-24T18:00:18.787 に答える
1

Martin Rの答えは、あなたの問題がどこにあるかです。ただし、標準の for ++ ループの代わりに Objective-C の高速列挙を含めるようにロジックを変更します。また、読みやすくするために、2 番目の for ループを BOOL メソッドに分離しました。

for (NSDictionary *dataDict in responseObj) {
    NSString *event_name =[dataDict objectForKey:@"event_name"];
    if ([self matchFoundForEventId:event_name]) {
        NSLog(@"Match found");
    }
}

-(BOOL)matchFoundForEventId:(NSString *)eventId {
    for (NSDictionary *dataDict in createList) {
        NSString *createEvent = [dataDict objectForKey:@"event_id"];
        if ([eventId isEqualToString:createEvent]) {
            return YES;
        }
    }
    return NO;
}
于 2013-07-24T18:11:43.200 に答える