逐行读取文件中的数据,并将数据存储于二维列表中,将每个子列表中可转为数值类型的数据均转为数值类型。输入一个正整数做为随机数种子,随机抽取两个站点的数据,应用本关提供的计算方法计算并这两个站点之间的距离。 输入一个整数做随机数种子,输出抽取到的点的经纬度和两点间距离。

时间: 2024-02-18 20:06:10 浏览: 24
好的,我可以帮你解决这个问题。 首先,我需要明确你的文件格式。假设你的数据文件每行包含站点名称、经度、纬度和其他信息,以逗号分隔。那么你可以按照以下代码读取并处理数据: ```python import random # 读取数据文件 data = [] with open('data.txt', 'r') as f: for line in f: fields = line.strip().split(',') # 将可转为数值类型的数据转为数值类型 data.append([fields[0], float(fields[1]), float(fields[2]), fields[3:]]) # 随机抽取两个站点 random.seed(123) # 设置随机数种子 idx1, idx2 = random.sample(range(len(data)), 2) site1, site2 = data[idx1], data[idx2] # 计算两点间距离 def distance(lat1, lon1, lat2, lon2): R = 6371 # 地球半径,单位为公里 dlat = (lat2 - lat1) * math.pi / 180 dlon = (lon2 - lon1) * math.pi / 180 a = math.sin(dlat / 2) * math.sin(dlat / 2) + \ math.cos(lat1 * math.pi / 180) * math.cos(lat2 * math.pi / 180) * \ math.sin(dlon / 2) * math.sin(dlon / 2) c = 2 * math.atan2(math.sqrt(a), math.sqrt(1 - a)) return R * c lat1, lon1 = site1[2], site1[1] lat2, lon2 = site2[2], site2[1] dist = distance(lat1, lon1, lat2, lon2) # 输出结果 print('站点1:{},经度:{},纬度:{}'.format(site1[0], lat1, lon1)) print('站点2:{},经度:{},纬度:{}'.format(site2[0], lat2, lon2)) print('两点间距离:{:.2f} km'.format(dist)) ``` 在上面的代码中,我使用了 Python 自带的 `random` 模块来随机抽取两个站点,使用了 `math` 模块来计算两点间距离。请将代码中的 `'data.txt'` 替换为你的数据文件名,并将随机数种子改为你需要的值。运行代码后,你将获得抽取的两个站点的经纬度和它们之间的距离。

相关推荐

最新推荐

recommend-type

Shell脚本从文件中逐行读取内容的几种方法实例

今天小编就为大家分享一篇关于Shell脚本从文件中逐行读取内容的几种方法实例,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
recommend-type

Python实现读取txt文件中的数据并绘制出图形操作示例

主要介绍了Python实现读取txt文件中的数据并绘制出图形操作,涉及Python文件读取、数值运算及基于pylab库的图形绘制相关操作技巧,需要的朋友可以参考下
recommend-type

C++从文本文件读取数据到vector中的方法

主要给大家介绍了利用C++如何从文本文件读取数据到vector中,文章通过实例给出示例代码,相信会对大家的理解和学习很有帮助,有需要的朋友们下面来一起看看吧。
recommend-type

C++读取WAV音频文件的头部数据的实现方法

主要介绍了C++读取WAV音频文件的头部数据的实现方法的相关资料,希望通过本文能帮助到大家,让大家实现这样的方法,需要的朋友可以参考下
recommend-type

C#实现读取DataSet数据并显示在ListView控件中的方法

主要介绍了C#实现读取DataSet数据并显示在ListView控件中的方法,涉及C#操作DataSet及ListView控件的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

可见光定位LED及其供电硬件具体型号,广角镜头和探测器,实验设计具体流程步骤,

1. 可见光定位LED型号:一般可使用5mm或3mm的普通白色LED,也可以选择专门用于定位的LED,例如OSRAM公司的SFH 4715AS或Vishay公司的VLMU3500-385-120。 2. 供电硬件型号:可以使用常见的直流电源供电,也可以选择专门的LED驱动器,例如Meanwell公司的ELG-75-C或ELG-150-C系列。 3. 广角镜头和探测器型号:一般可采用广角透镜和CMOS摄像头或光电二极管探测器,例如Omron公司的B5W-LA或Murata公司的IRS-B210ST01。 4. 实验设计流程步骤: 1)确定实验目的和研究对象,例如车辆或机器人的定位和导航。
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。