按时间戳匹配点云和图像数据

process_data.py

#encoding:utf-8
# !/usr/bin/python'''
USE Method:python process_data.py
1.点云pcd文件名是按时间戳保存的.2.相机pic文件名是按时间戳保存的。
此文档是根据点云和图像时间戳,匹配点云和图像数据。
'''import os
import sys
import argparse
import os.path
import shutilpath =  os.path.abspath('.')def parse_args():"""Parse input arguments"""parser = argparse.ArgumentParser(description='cut pic and xml 1 to 2')parser.add_argument('--pcd', dest='pcd',default = "pcd", type=str)parser.add_argument('--pic', dest='pic',default = "pic",type=str)# if len(sys.argv) == 1:#     parser.print_help()#     sys.exit(1)args = parser.parse_args()return argsif __name__ == '__main__':args = parse_args()print('Called with args:')print(args)path_pcd = "/media/data/zs/project/天准车机/caiji/230601/pcd"path_pic = "/media/data/zs/project/天准车机/caiji/230601/png"pcd = "2023-05-29-17-09-19"pic = "2023-05-29-17-09-19/camera_6"pcd_path = os.path.join(path_pcd , pcd)pic_path = os.path.join(path_pic , pic)timestamp = 200 #ms# dst_pcd_path = path_pcd + '/' + "not_pic"dst_pic_path = path_pcd + '/' + "camera_6"if not os.path.exists(dst_pic_path):os.mkdir(dst_pic_path)else:print("此目录已存在!")sys.exit(1)# if not os.path.exists(dst_pcd_path):#     os.mkdir(dst_pcd_path)# else:#     print("此目录已存在!")#     sys.exit(1)# for file in os.listdir(pic_path):#     pcd_name = os.path.join(pcd_path, os.path.splitext(file)[0] + ".pcd")#     if os.path.exists(pcd_name):#         print("This file", file, "has pcd !")#     elif not os.path.exists(pcd_name):#         print("This file", file, "has not pcd !")#         shutil.move(os.path.join(pic_path,file), dst_pic_path)for file in os.listdir(pcd_path):pcd_name_int = (int)(os.path.splitext(file)[0])# print(pcd_name_int)# print("------------------------------")is_matching = Falsefor pic_file in os.listdir(pic_path):pic_name_int = (int)(os.path.splitext(pic_file)[0])if abs(pcd_name_int - pic_name_int) < timestamp:#os.rename(filepath,newpath)old_pic_path = os.path.join(pic_path , pic_file)shutil.copy(old_pic_path, dst_pic_path)new_pic_path = os.path.join(dst_pic_path , str(pcd_name_int)+".jpg")print(old_pic_path)print(new_pic_path)os.rename(os.path.join(dst_pic_path , pic_file),new_pic_path)is_matching = Truebreakif is_matching == False:for pic_file in os.listdir(pic_path):pic_name_int = (int)(os.path.splitext(pic_file)[0])if abs(pcd_name_int - pic_name_int) < timestamp*2:#os.rename(filepath,newpath)old_pic_path = os.path.join(pic_path , pic_file)shutil.copy(old_pic_path, dst_pic_path)new_pic_path = os.path.join(dst_pic_path , str(pcd_name_int)+".jpg")print(old_pic_path)print(new_pic_path)os.rename(os.path.join(dst_pic_path , pic_file),new_pic_path)breakprint("Done!")#pic_path = os.path.join(pic_path, pic_name)#shutil.move(xml_name, dst_path)#for dirpath, dirnames, filenames in os.walk("f:/"):#   for filename in filenames:#      if os.path.splitext(filename)[1] == ".txt":#        print filepath#        copy(filepath, "F:/test/" + filename)#       Shutil.move(changeFilePath, dst_path)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/20677.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

vue3实现拖拽排序

效果&#xff1a; 实现 <template><div class"box"><divv-for"(item, index) in items":key"item.id"class"item":style"{ order: item.order }":draggable"true"dragstart"onDragStart(in…

【测试联调】如何在前后端测试联调时优雅的构造异常场景

目录 背景 使用iptables实现 利用iptables丢弃某ip数据包 使用 -L 列出所有规则 IP 连通性 通信 测试 插入一条规则&#xff0c;丢弃此ip 的所有协议请求 列出所有规则 测试 丢弃规则内的IP 连通性 清除 规则列表的 限制 模拟ip进行丢包50%的处理。 mysql proxy 代理…

脑电信号处理与特征提取——6.运用机器学习技术和脑电进行大脑解码(涂毅恒)

目录 六、运用机器学习技术和脑电进行大脑解码 6.1 前言 6.2 基于脑电数据的机器学习基础分析 6.3 基于脑电数据的机器学习进阶分析 6.4 代码解读 六、运用机器学习技术和脑电进行大脑解码 6.1 前言 6.2 基于脑电数据的机器学习基础分析 6.3 基于脑电数据的机器学习进阶分…

快速增加Shopee,lazada店铺销量的秘籍大揭秘

在竞争激烈的电商市场中&#xff0c;如何快速提高Shopee。lazada店铺的销量一直是卖家们关注的焦点。 优化产品信息&#xff1a;在Shopee平台上&#xff0c;完整填写产品标题、描述和关键词等信息非常重要。确保您的产品信息准确、清晰&#xff0c;并包含与目标买家搜索相关的…

C语言笔试题训练【第一天】

目录 第一题 第二题 第三题 第四题 第五题 大家好&#xff0c;我是纪宁。 从今天开始博主会日更一些经典的C语言笔试题&#xff0c;持续20天左右。题目类型为5道选择题加2道编程题&#xff0c;希望能和大家一起进步。 第一题 1.读程序&#xff0c;下面程序正确的输出是&…

如何在Visual Studio Code中用Mocha对TypeScript进行测试

目录 使用TypeScript编写测试用例 在Visual Studio Code中使用调试器在线调试代码 首先&#xff0c;本文不是一篇介绍有关TypeScript、JavaScript或其它编程语言数据结构和算法的文章。如果你正在准备一场面试&#xff0c;或者学习某一个课程&#xff0c;互联网上可以找到许多…

微信小程序wx.getlocation接口权限申请总结

先附上申请通过截图 插播内容&#xff1a;可代开通&#xff0c;保证通过。wx.getLocation接口&#xff08;获取当前的地址位置&#xff09; qq&#xff1a; 308205428 如何申请 当申请微信小程序的wx.getLocation接口权限时&#xff0c;你可以…

Go语言进阶语法八万字详解,通俗易懂

文章目录 File文件操作FileInfo接口权限打开模式File操作文件读取 I/O操作io包 文件复制io包下的Read()和Write()io包下的Copy()ioutil包总结 断点续传Seeker接口断点续传 bufio包bufio包原理Reader对象Writer对象 bufio包bufio.Readerbufio.Writer ioutil包ioutil包的方法示例…

gitlab CI/CD 安装 gitlab runner

一、为什么需要安装gitlab runner &#xff1f; 极狐GitLab Runner 极狐GitLab Runner 是在流水线中运行作业的应用&#xff0c;与极狐GitLab CI/CD 配合运作。 说白了就是你部署的一个agent。 二、如何安装&#xff1f; 1.介绍通过helm部署github runner 2.helm添加仓库 h…

游戏引擎:打造梦幻游戏世界的秘密武器

介绍 游戏引擎是游戏开发中不可或缺的工具&#xff0c;它为开发者提供了构建游戏世界所需的各种功能和工具。本文将介绍游戏引擎的概念、使用方法以及一个完整的游戏项目示例。 游戏引擎的概念 游戏引擎是一种软件框架&#xff0c;它提供了游戏开发所需的各种功能和工具&…

【Java可执行命令】(十四)脚本执行工具jrunscript :在命令行环境下交互式执行一些简单的脚本或测试代码片段~

Java可执行命令之jrunscript 1️⃣ 概念2️⃣ 优势和缺点3️⃣ 使用3.1 语法格式3.2 启动 jrunscript 直接执行脚本3.3 可选参数&#xff1a;-l < language>3.4 可选参数&#xff1a;-e < script>3.5 可选参数&#xff1a;-f < script file>3.6 注意事项 4️…

大模型开发(十五):从0到1构建一个高度自动化的AI项目开发流程(上)

全文共5600余字&#xff0c;预计阅读时间约13~20分钟 | 满满干货(附全部代码)&#xff0c;建议收藏&#xff01; 本文目标&#xff1a;提出一种利用大语言模型(LLMs)加快项目的开发效率的解决思路&#xff0c;本文作为第一部分&#xff0c;主要集中在如何完整的执行引导Chat模…

VSCode新手快速下载、安装、使用

目录 下载 安装 1、许可协议 2、安装位置 3、开始菜单文件夹 4、附加任务 5、确认安装 6、完成 使用 1、汉化&#xff08;设置中文界面&#xff09; 2、设置 下载 进入VSCode官方页面&#xff0c;选择自己系统对应的下载链接VSCode默认提供的User Installer版本。但…

如何使用大模型处理生活繁琐的工作

如果每封电子邮件、每个带有订单、发票、投诉、录用请求或工作申请的 PDF 都可以翻译成机器可读的数据&#xff0c;会怎样&#xff1f;然后可以由 ERP / CRM / LMS / TMS 自动处理吗&#xff1f;无需编程特殊接口。 听起来很神奇&#xff1f;它确实有一些魔力。但最近已成为可…

SpringBoot引入MyBatisGenerator

1.引入插件 <plugin><groupId>org.mybatis.generator</groupId><artifactId>mybatis-generator-maven-plugin</artifactId><version>1.3.5</version><configuration><!--generator配置文件所在位置--><configuratio…

Python web实战之 Django 的 ORM 框架详解

本文关键词&#xff1a;Python、Django、ORM。 概要 在 Python Web 开发中&#xff0c;ORM&#xff08;Object-Relational Mapping&#xff0c;对象关系映射&#xff09;是一个非常重要的概念。ORM 框架可以让我们不用编写 SQL 语句&#xff0c;就能够使用对象的方式来操作数据…

STM32CUBUMX配置RS485 modbus STM32(从机)亲测可用

———————————————————————————————————— ⏩ 大家好哇&#xff01;我是小光&#xff0c;嵌入式爱好者&#xff0c;一个想要成为系统架构师的大三学生。 ⏩最近在开发一个STM32H723ZGT6的板子&#xff0c;使用STM32CUBEMX做了很多驱动&#x…

怎么才能远程控制笔记本电脑?

为什么选择AnyViewer远程控制软件&#xff1f; 为什么AnyViewer是远程控制笔记本电脑软件的首选&#xff1f;以下是选择AnyViewer成为笔记本电脑远程控制软件的主要因素。 跨平台能力 AnyViewer作为一款跨平台远程控制软件&#xff0c;不仅可以用于从一台Windows电…

【BEV感知】3-BEV开源数据集

3-BEV开源数据集 1 KITTI1.1 KITTI数据怎么采集?1.2 KITTI数据规模有多大?1.3 KITTI标注了哪些目标?1.4 转换矩阵1.5 标签文件 2 nuScenes2.1 nuScenes Vs KITTI2.2 标注文件 1 KITTI KITTI 1.1 KITTI数据怎么采集? 通过车载相机、激光雷达等传感器采集。 只提供了相机正…

蓝桥杯上岸每日N题 第七期(小猫爬山)!!!

蓝桥杯上岸每日N题 第七期(小猫爬山)&#xff01;&#xff01;&#xff01; 同步收录 &#x1f447; 蓝桥杯上岸必背&#xff01;&#xff01;&#xff01;(第四期DFS) 大家好 我是寸铁&#x1f4aa; 冲刺蓝桥杯省一模板大全来啦 &#x1f525; 蓝桥杯4月8号就要开始了 &a…