首页 > 编程语言 >盘点一个使用Python自动化处理GPS、北斗经纬度数据实战(下篇)

盘点一个使用Python自动化处理GPS、北斗经纬度数据实战(下篇)

时间:2023-09-25 22:58:19浏览次数:38  
标签:下篇 经纬度 Python 代码 df 数据 columns GPS

大家好,我是皮皮。

一、前言

上一篇文章我们使用了Python来实现数据的导入和分列处理,最终可以得到符合预期的结果,不过还可以继续深挖优化下,这一篇文章一起来看看吧。优化的背景如下图所示:

image.png

二、实现过程

这里【瑜亮老师】继续给了一个优化指导,如下图所示:

image.png

并且给出的代码如下:

with open("./GpsSnr.txt", "r", encoding="utf-8") as f:
    txt = f.readlines()
regex =r"\((\d+,\d+\.\d+)\)"
temp = [re.findall(regex, x) for x in txt]
df = pd.DataFrame(temp)
# 这样保存下来的就是经纬度在一起的
# df.to_excel('GpsSnr1.xlsx', index=False)

# 下面是把经纬度分开
data = []
for i in df.columns:
    data.append(df[i].str.split(',', expand=True))
df = pd.concat(data, axis=1)
df.columns = [a+str(b) for a in ['gps','glnoss','beidou'] for b in range(10)]
# print(df.head())
df.to_excel('GpsSnr2.xlsx', index=False)

下图是部分指导:

image.png

顺利地解决了粉丝的问题。

其实分成3列更容易进行研究,比如需要对分类为beidou,经纬度在某个范围内的数据进行研究,分成3列这种只需要进行简单的筛选就可以提取出来数据。而分成30列的,就需要对columns进行提取,再处理经纬度,比较麻烦。后来【瑜亮老师】还继续推演,感兴趣的小伙伴们也可以尝试下哦。

image.png

三、总结

大家好,我是皮皮。这篇文章主要盘点了一个Python自动化办公的问题,文中针对该问题,给出了具体的解析和代码实现,帮助粉丝顺利解决了问题。

最后感谢粉丝【灰崽】提问,感谢【瑜亮老师】、【王者级混子】给出的思路和代码解析,感谢【甯同学】、【莫生气】、【kim】、【

标签:下篇,经纬度,Python,代码,df,数据,columns,GPS
From: https://www.cnblogs.com/dcpeng/p/17729054.html

相关文章

  • Python RuntimeError: dictionary changed size during iteration
    运行下面代码,报如下错误fornameinglobals():print(name) 解决办法是:将待遍历的对象转换成列表fornameinlist(globals()):print(name) ......
  • poython文件运行模式和python控制台运行模式和Juputer运行模式
    今天学pytorch,我知道了python文件是整个代码运行,,而python控制台是一行一行的运行。而Juputer是任意代码块运行的。 ......
  • Python与Java的语法区别
    数据容器/数组/集合Python:对数据容器的操作#对list进行切片,从1开始,4结束,步长1(默认步长为1)my_list=[0,1,2,3,4,5,6]result1=my_list[1:4]print(f"结果1:{result1}")#对tuple进行切片,从头开始,到最后结束,步长1my_tuple=(0,1,2,3,4,5,6)result2=my_tu......
  • Python-day18
    1、常用的文件打开模式rfile=open('a.txt','r')print(file.readlines())file.close()wfile=open('a.txt','w')file.write('whywhywhy')file.close()afile=open('a.txt','a')file.write('whywhywhy......
  • Python学习笔记1
    a="好的,测试字符tester"b=17c=3print(a[1:5])#从第1(包含)个字符取到第5(不包含)个字符print(a[:3])#取到第3个字符(不含3)print(a[-5:-1])#取倒数第5个到倒数第1个print(a[-1:])#取最后一个字符print(len(a))#字符长度#exit()#退出与quit()一样,里面......
  • python2 http服务端和客户端
    server.pyimportSimpleHTTPServerimportSocketServerclassMyHandler(SimpleHTTPServer.SimpleHTTPRequestHandler):defdo_GET(self):self.send_response(200)self.send_header('Content-type','text/plain')self......
  • Python的Selenium库:网页元素定位工具
    Selenium是一个用于自动化web应用测试的开源工具。通过Selenium,我们可以模拟真实用户的操作,如点击、输入、滚动页面等,来测试web应用的稳定性和可靠性。PythonSelenium库是Selenium的一个分支,可以方便地与Python语言结合使用。在PythonSelenium库中,元素定位是一项核心功能。通过......
  • NumPy:Python科学计算基础包
    NumPy是Python科学计算的基础包,几乎所有用Python工作的科学家都利用了的强大功能。此外,它也广泛应用在开源的项目中,如:Pandas、Seaborn、Matplotlib、scikit-learn等。Numpy全称NumericalPython。它提供了2种基本的对象:ndarray与ufunc。ndarray是存储单一数据的多维数组,它......
  • Python IEEE754 单精度浮点数二进制十六进制转换
    在学计组的知识,单精度浮点数与二进制十六进制的转换过程,写了几个函数,方便自己检验1hdict={2'0':'0000',3'1':'0001',4'2':'0010',5'3':'0011',6'4':'0100&......
  • python的zip()和zip(*)函数
    zip是打包为元组的列表;zip(*[xx])是把列表解压为两个元组,相当于zip的逆过程,可用于矩阵转置。参考:https://blog.csdn.net/ezio23/article/details/81414092......