繁体   English   中英

有关在Python中解析tsv文件的查询

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM