python将指定点云文件(asc)转换为PCD格式
admin
2023-07-31 01:47:05
0

起因

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

着手写作

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

#coding:utf-8
import time
from sys import argv
script ,filename = argv
print (\"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+1
print (\"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

相关内容

热门资讯

Mobi、epub格式电子书如... 在wps里全局设置里有一个文件关联,打开,勾选电子书文件选项就可以了。
定时清理删除C:\Progra... C:\Program Files (x86)下面很多scoped_dir开头的文件夹 写个批处理 定...
scoped_dir32_70... 一台虚拟机C盘总是莫名奇妙的空间用完,导致很多软件没法再运行。经过仔细检查发现是C:\Program...
500 行 Python 代码... 语法分析器描述了一个句子的语法结构,用来帮助其他的应用进行推理。自然语言引入了很多意外的歧义,以我们...
小程序支付时提示:appid和... [Q]小程序支付时提示:appid和mch_id不匹配 [A]小程序和微信支付没有进行关联,访问“小...
pycparser 是一个用... `pycparser` 是一个用 Python 编写的 C 语言解析器。它可以用来解析 C 代码并构...
微信小程序使用slider实现... 众所周知哈,微信小程序里面的音频播放是没有进度条的,但最近有个项目呢,客户要求音频要有进度条控制,所...
65536是2的几次方 计算2... 65536是2的16次方:65536=2⁶ 65536是256的2次方:65536=256 6553...
Apache Doris 2.... 亲爱的社区小伙伴们,我们很高兴地向大家宣布,Apache Doris 2.0.0 版本已于...
项目管理和工程管理的区别 项目管理 项目管理,顾名思义就是专注于开发和完成项目的管理,以实现目标并满足成功标准和项目要求。 工...