滑稽家的大家长 2022-12-07 22:47 采纳率: 33.3%
浏览 10
已结题

利用python计算折线的坐标

给你一个含大量坐标,坐标处在点集的字典,如何用Python计算折线长度
{
"points": [
[
244.8598130841,
339.2523364486
],
[
228.9719626168,
505.6074766355
],
[
902.8037383178,
525.2336448598
],
[
1736.8985507246,
508.768115942
]
]
}

  • 写回答

2条回答 默认 最新

  • ShowMeAI 2022-12-07 23:00
    关注

    望采纳


    可以用Python的内置函数 math.sqrt() 来计算两个点之间的欧几里得距离,然后把这些距离相加起来就可以得到折线的总长度了。下面是一个例子:

    import math
    
    # 定义一个含有坐标的字典
    points = {
        "points": [
            [244.8598130841, 339.2523364486],
            [228.9719626168, 505.6074766355],
            [902.8037383178, 525.2336448598],
            [1736.8985507246, 508.768115942]
        ]
    }
    
    # 定义一个函数来计算两个点之间的欧几里得距离
    def euclidean_distance(point1, point2):
        return math.sqrt((point1[0] - point2[0])**2 + (point1[1] - point2[1])**2)
    
    # 定义一个函数来计算折线的总长度
    def polyline_length(points):
        length = 0
        for i in range(1, len(points)):
            length += euclidean_distance(points[i-1], points[i])
        return length
    
    # 计算折线的总长度
    length = polyline_length(points["points"])
    print(length)  # 输出:2071.95901463799
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 12月16日
  • 已采纳回答 12月8日
  • 创建了问题 12月7日

悬赏问题

  • ¥15 基于RTKLIB框架写的精密单点定位-AR
  • ¥15 PFENet的预训练权重
  • ¥15 程序哪有错误怎么改?
  • ¥15 交换机和交换机之间的链路带宽以及主机带宽的理解
  • ¥15 ai创想家对战模式代码
  • ¥15 集合A由3个2行4列二维数组构成,从集合A中任意取一个二维数组元素、如果该二维数组元素的对应列位置的上、下两数都是奇数,而且仅有2个列是奇数/奇数,则该数组有意义,并放入集合B中打印输出。
  • ¥15 电信IPV6 无法外网访问吗
  • ¥15 有偿求效果比较好的遥感影像匹配的c++代码
  • ¥15 博主,你好,我下载了你的智能网联汽车辅助驾驶安全信息检测系统,现在不会运行,可以教我吗,
  • ¥15 怎么在excle输入下列公式