我有巴西政府当局提供的这个小 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(返回正常邮政编码)并搜索以查看哪个记录适合我需要城市代码的给定邮政编码。
有些对我来说看起来不是最好的,但令我惊讶的是,代码非常快,虽然在一个循环中。
我会很感激评论...
谢谢,