Я пытаюсь написать программу, которая вычисляет определенную формулу, основываясь на zipcode, lat и lng.

Моей первоначальной идеей было создать объект для каждого почтового индекса.

class destination():
def __init__(self, zipcode, count):
    self.zipcode = zipcode
    self.count = count

def getCount(self):
    return self.count

def getZip(self):
    return self.zipcode

def getLatitude(self):
    return self.lat 

def getLongitude(self):
    return self.lng 

def __str__(self):
    return "%s at %s , %s" % (self.zipcode, self.lat, self.lng)

def getCoords(self):
    '''
    Must be called before getLatitude or get Longitude
    '''
    self.place, (self.lat, self.lng) = gn.geocode(str(self.zipcode))  
    self.city = self.place.split(",",1)
    self.name =  self.city[0]
    self.value = str(count)+","+self.name

    return self.value

Это прекрасно работает, так как я могу успешно перебирать список, создавать объект и извлекать из него необходимую информацию.

zipList = ['54971','46383','90210']

for i in zipList:
    i = destination(i,count)
        count += 1

Вернется

1,Ripon
-88.8359447
43.8422049
2,Valparaiso
-87.0611412
41.4730948
3,Beverly Hills
-118.4003563
34.0736204

Кажется, я не могу понять, как настроить программу так, чтобы она перебирала список, вызывая функцию haversine с правильной информацией для каждого элемента.

def haversine(latStart,lonStart,latEnd,lonEnd):

Пример: из моего списка

zipList = ['54971','46383','90210']

Затем он выполнит расчет для 54971 до 46383, 54971 до 90210 и от 46383 до 90210

1
Alex 25 Янв 2013 в 03:34

4 ответа

Лучший ответ

Запросите все пары почтовых индексов из списка и используйте их:

import itertools

for start, stop in itertools.combinations(zipList, 2):
    print start, stop
    # now pass start, stop to your function
3
alexis 24 Янв 2013 в 23:44

Попробуйте использовать itertools, функция комбинаций может быть тем, что вам нужно.

3
ChipJust 24 Янв 2013 в 23:42

Вы можете создать список целевых объектов, получить комбинации из созданного списка и выполнить итерацию возвращаемого генератора с помощью функции haversine.

dests = []
for i in zipList:
    dests.append(destination(i,count))
    count += 1

dests_gen = itertools.combinations(dests, 2)
for dest_typle in dests_gen:
    pass
0
Ifthikhan 24 Янв 2013 в 23:50

Короткий ответ:

for a, b in ( (a, b) for a in zipList for b in zipList):
    print (a, b, distance (a, b) )

Некоторые комментарии: Вам не нужно брать ручное управление «count», если вы делаете его переменной класса. Вы можете использовать свойства для определения местоположения вашей точки по требованию (т. Е. При первом доступе к lat или lon). Вам не нужны методы получения, если свойства общедоступны (если API не требует этого). Может быть как то так

#! /usr/bin/python3.2

def haversine (latStart,lonStart,latEnd,lonEnd): return 42

class Destination():
    count = 0

    def __init__(self, zipcode):
        self.zipcode = zipcode
        self.count = self.__class__.count
        self.__class__.count += 1
        self.__coords = None

    @property
    def latitude (self):
        if not self.__coords: self.__locate ()
        return self.__coords [0]

    @property
    def longitude (self):
        if not self.__coords: self.__locate ()
        return self.__coords [1]

    def __str__(self):
        return "%s at %s , %s" % (self.zipcode, self.latitude, self.longitude)

    def __locate (self):
        '''
        Will be called automatically before getLatitude or get Longitude
        '''
        self.place, self.__coords = gn.geocode (str (self.zipcode) )  
        self.city = self.place.split (",",1)
        self.name =  self.city [0]

    def distance (self, other):
        return haversine (self.latitude, self.longitude, other.latitude, other.longitude)
0
Hyperboreus 25 Янв 2013 в 00:05