博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python将指定点云文件(asc)转换为PCD格式
阅读量:7055 次
发布时间:2019-06-28

本文共 1272 字,大约阅读时间需要 4 分钟。

起因

由于自己大部分的点云文件都是.asc格式的,但最近用pcl做点云方面的研究,从asc文件到pcd文件手动转化太麻烦,而且效率较低,故此写一个不太成熟的python脚本实现从asc文件到pcd格式文件的转换。

ps此脚本只适用于ASCII编码的文件,并且只适用于散乱点云

着手写作

分析pcd文件的格式可知,从asc到pcd转换最根本要求就是其文件开头符合pcd格式要求,其中最主要的问题是的是如何动态设置WIDTHPOINTS的值,对于散乱点云,这两个值都可以表示点数.点数的获得可用asc文件的行数表示.

代码如下:

#coding:utf-8import timefrom sys import argvscript ,filename = argvprint ("the input file name is:%r." %filename)start = time.time()print ("open the file...")file = open(filename,"r+")count = 0#统计源文件的点数for line in file:    count=count+1print ("size is %d" %count)file.close()#output = open("out.pcd","w+")f_prefix = filename.split('.')[0]output_filename = '{prefix}.pcd'.format(prefix=f_prefix)output = open(output_filename,"w+")list = ['# .PCD v.5 - Point Cloud Data file format\n','VERSION .5\n','FIELDS x y z\n','SIZE 4 4 4\n','TYPE F F F\n','COUNT 1 1 1\n']output.writelines(list)output.write('WIDTH ') #注意后边有空格output.write(str(count))output.write('\nHEIGHT')output.write(str(1))  #强制类型转换,文件的输入只能是str格式output.write('\nPOINTS ')output.write(str(count))output.write('\nDATA ascii\n')file1 = open(filename,"r")all = file1.read()output.write(all)output.close()file1.close()end = time.time()print ("run time is: ", end-start)

实例

以20万左右的点云为例,该脚本运行时间大约在0.14s左右,基本可以满足自己的需求

转换前

转换后

运行以上脚本,便可自动将example.asc转化为example.pcd

转载地址:http://bglol.baihongyu.com/

你可能感兴趣的文章
配置Log4j(非常具体)
查看>>
SQL语句技巧之去除重复行
查看>>
MapReduce On YARN
查看>>
poj 2377 Bad Cowtractors
查看>>
积累的一些代码片段/小知识
查看>>
关于PCA算法的一点学习总结
查看>>
Java 之文件IO编程 之写入
查看>>
centos6.4安装Vmware exsi CLI
查看>>
[PeterDLax著泛函分析习题参考解答]第7章 Hilbert 空间结果的应用
查看>>
存储过程之七—java代码调用
查看>>
Repository 仓储,你的归宿究竟在哪?(三)-SELECT 某某某。。。
查看>>
【BZOJ】1684: [Usaco2005 Oct]Close Encounter(暴力+c++)
查看>>
切入点表达式解析
查看>>
.Net魔法堂:AssemblyInfo.cs文件详解
查看>>
(转)NGUI制作转圈的技能CD特效
查看>>
Spring JMX之三:通知的处理及监听
查看>>
Python 函数
查看>>
【剑指offer】合并两有序单链表
查看>>
HDU 4360 As long as Binbin loves Sangsang spfa
查看>>
IT痴汉的工作现状24-Just for fun
查看>>