0

我有巴西政府当局提供的这个小 excel 文件,它包含巴西每个城市的记录,每个城市的邮政编码范围及其“城市代码”。

我需要检索给定城市的“城市代码”。

我想最好的方法是根据显示邮政编码范围的前两列解析城市的给定邮政编码并返回其“城市代码”。

我相信使用 AppleScript 可以为给定的 Excel 文件编译 plist 文件。但是,一旦我解析了邮政编码,有人可以指点我几行 ObjectiveC 代码来从 plist 文件中检索给定的条目吗?

请参阅http://www.idanfe.com/dl/codes.xls.zip上的 excel 文件

谢谢。

我已将示例 plist 文件上传到http://www.idanfe.com/dl/cityCodes.plist

进一步说明:

我将解析一个邮政编码值,例如:01123010,它在 01001000 和 05895490 的范围内,所以我的例程应该返回城市代码 = 3550308 和城市名称 = 圣保罗。

我不知道如何实现这一点,我可能错误地构建了示例 plist。

我相信我可以使用 AppleScript 构建一个 plist 文件,从 Excel 表中读取。

但是检索给定邮政编码范围的城市代码是一个难题。

+++ 编辑:+++

我想我已经解决了它,但它看起来有点笨拙,就像我写的几乎所有东西一样。

此 AppleScript 读取 Excel 表并写入 plist 文件:http ://www.idanfe.com/dl/creating.scpt.zip

在这里您可以找到 1 MB plist 文件:http ://www.idanfe.com/dl/cityCodes.plist.zip

这是我为获取所需的城市代码而编写的代码:

NSString *zipCodeString;
zipCodeString = @"99990000";

NSString* plistPath = [[NSBundle mainBundle] pathForResource:@"cityCodes" ofType:@"plist"];
NSDictionary *cityCodes_dictionary = [NSDictionary dictionaryWithContentsOfFile:plistPath];
NSArray *allKeys = [cityCodes_dictionary allKeys];

int i = 0;
for (i = 0 ; i <= [allKeys count]; i++) {
    NSString *someKey = [allKeys objectAtIndex:i];
    NSRange range08 = NSMakeRange (0, 8);
    NSRange range88 = NSMakeRange (8, 8);
    NSString *startZipCode = [someKey substringWithRange:range08];
    NSString *finalZipCode = [someKey substringWithRange:range88];
    int startZipCodeInt = [startZipCode intValue];
    int finalZipCodeInt = [finalZipCode intValue];

    if(startZipCodeInt <= [zipCodeString intValue] && finalZipCodeInt >= [zipCodeString intValue]){
        NSLog(@"we found a winner");
        NSString *cityCode = [NSString stringWithFormat: @"%@",[[cityCodes_dictionary objectForKey:someKey]objectForKey:@"City Code"]];

        [cityCodeIBGEField setStringValue:cityCode];
        NSLog(@"cityCode = %@",cityCode);
        break;
    } else {
       // NSLog(@"no winners");
    }
}

基本上,我将起始邮政编码和最终邮政编码附加到一个 16 位数字的字符串中,因此我在 plist 文件中创建了一条记录。

然后,在搜索城市代码时,我将长键(2 个邮政编码)分解为 2(返回正常邮政编码)并搜索以查看哪个记录适合我需要城市代码的给定邮政编码。

有些对我来说看起来不是最好的,但令我惊讶的是,代码非常快,虽然在一个循环中。

我会很感激评论...

谢谢,

4

2 回答 2

1

我会使用 indexOfObjectPassingTest: 来做这种搜索。像这样的东西:

- (void)applicationDidFinishLaunching:(NSNotification *)aNotification {

    NSString* plistPath = [[NSBundle mainBundle] pathForResource:@"cityCodes" ofType:@"plist"];
    self.cityCodes_dictionary = [NSDictionary dictionaryWithContentsOfFile:plistPath];
    [self findCityWithZip:@"01123010"];
}

-(void)findCityWithZip:(NSString *) searchZip {
    NSUInteger indx = [self.cityCodes_dictionary.allKeys indexOfObjectPassingTest:^BOOL(NSString *zip, NSUInteger idx, BOOL *stop) {
        NSString *startZipCode = [zip substringWithRange:NSMakeRange(0, 8)];
        NSString *finalZipCode = [zip substringWithRange:NSMakeRange(8, 8)];
        return (searchZip.integerValue < finalZipCode.integerValue && searchZip.integerValue > startZipCode.integerValue);
    }];
    NSLog(@"%@",[self.cityCodes_dictionary valueForKey:[self.cityCodes_dictionary.allKeys objectAtIndex:indx]]);
}
于 2012-10-22T04:18:53.590 回答
0

如果 plist 结构为字典,则阅读 plist 根本不成问题:

NSDictionary *dict = [NSDictionary dictionaryWithContentsOfFile: @"cities.plist"];
//NSString *zipStr = [dict valueForKey: @"CityNme"]; //this was an example

那是容易的部分。较难的部分是从 xls 文件解析和构建 plist 文件。

还是我误解了你的问题?

PS:要快速查看字典的 plist 结构,请创建一个模拟字典和 NSLog 它的描述以查看它应该如何(或 writeToFile 以查看文件内容或当然参考文档)

编辑

您使用上面的代码将提供的 plist 文件加载到字典中。然后你使用从中检索另一个字典

 NSDictionary *city = [dict valueForKey : @"yourZipCodeHere"];

从那本字典中,您可以得到这样的 cityCode

NSString *cityCode = [city valueOrKey: @"City Code"];

至于你的范围问题,我不确定我是否完全理解。但是您可以使用以下方式获取所有邮政编码的数组

NSArray *zipArray = [dict allKeys];

然后您可以简单地对其进行迭代以获得正确的邮政编码。

PS:我不太了解苹果脚本,并且会对您如何使用它将 xls 转换为 plist 感兴趣。

于 2012-10-19T15:59:47.470 回答