[英]Query regarding tsv file parsing in Python
我已经编写了一个python函数,该函数将使用Google API计算两点之间的距离。 功能如下图所示:
导入urllib导入json作为simplejson
def calculateDistance(sourceLatitude, sourceLongitude, destinationLatitude, destinationLongitude):
sourceCoordinates = sourceLatitude, sourceLongitude
destinationCoordinates = destinationLatitude, destinationLongitude
url = "http://maps.googleapis.com/maps/api/distancematrix/json?origins={0}&destinations={1}&mode=driving&language=en-EN&sensor=false".format(str(sourceCoordinates),str(destinationCoordinates))
result= simplejson.load(urllib.urlopen(url))
resulting_distance = result['rows'][0]['elements'][0]['distance']['text']
print "The distance is: " + resulting_distance
#calculateDistance(5.341612, -3.913602,5.342044, -4.143452)
#calculateDistance(5.342044, -4.143452,5.341612, -3.913602)
我有一个tsv文件,看起来像这样:
-4.143452 5.342044
-3.913602 5.341612
-3.967045 5.263331
....
....
第一列代表经度,第二列代表经度。
现在,我想将这些值的每种组合传递给函数,以获取两点之间的距离。 有人可以让我知道一种有效的方法吗? tsv文件非常大。
Points=[]
with open('file.tsv','r') as f:
for line in f:
Points.append(line.strip().split('\t'))
for combo in itertools.combinations(Points, 2):
calculateDistance(combo[0][0], combo[0][1], combo[1][0], combo[1][1])
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.