对于那些遇到同样问题的人,这就是我最终解决问题的方法。
我从 Geonames.org 下载了一个制表符分隔列表,其中包含一个城市列表,其中还包含每个城市的奥尔森时区 ID。您可以从 Geoname 的导出转储链接(见下文)下载一些不同的列表,但我选择了 city5000.zip 列表,以便获得一个相当全面的城市列表,而不会过于臃肿。
您可以在以下链接中找到有关列表的下载链接和信息:http:
//download.geonames.org/export/dump/readme.txt
因为列表包含很多不必要的信息(例如 lat 和 lng 坐标),而且我需要数据为 .plist 格式以便在 iOS 应用程序中使用,所以我编写了一个简单的 Python 脚本从列表中提取城市名称和时区,根据城市名称按字母顺序对它们进行排序,然后转换为 .plist 格式。
对于那些感兴趣的人,python 脚本如下:
import json
import httplib
import os
cities = ()
rows = []
# Open up the tab delim list from Geonames.org
with open("cities15000.txt") as file:
lines = file.readlines()
# Reading each line in the list
for line in lines:
comps = line.split('\t')
city = comps[1].strip()
timezone = comps[17].strip()
# Make sure there are no duplicates
if not city in cities:
cities = cities + (city,)
row = {'city':city,'timezone':timezone}
rows = rows + [row,]
# Sort the rows based on the city name
def cmp(a,b):
if a['city'] > b['city']:
return 1
elif a['city'] == b['city']:
return 0
else:
return -1
rows.sort(cmp)
# Convert the array to json and then to plist
jsonString = json.dumps(rows)
with open("cities.json", "w") as jsonFile:
jsonFile.write(jsonString)
os.system('plutil -convert xml1 cities.json -o cities.plist')