OFF转PLY再转TXT

记录点云操作的时候发生的事情

最近在用SHREC14和13 的数据集,原始数据集的三维模型为OFF格式,为了转为点云走了一些弯路
接下来记录一下最终的代码。

`

STL,PLY,OFF格式相互转换

路径中不能有中文


import open3d as o3d
mesh = o3d.io.read_triangle_mesh("xx.off") #读取.off文件,stl
o3d.io.write_triangle_mesh("xx.ply",mesh) #存储新格式,stl,ply

'''OFF转PLY'''
import trimesh
def to_ply(input_path, output_path, original_type):
    mesh = trimesh.load(input_path, file_type=original_type)  # read file
    mesh.export(output_path, file_type='ply')  # convert to ply
to_ply('D:\\SHREC14/3D/M000003.off', 'D:\\SHREC14/test.ply', 'off')

'''读取PLY并保存txt'''


def read_ply_cloud(filename):
    ply_data = PlyData.read(filename)
    points = ply_data['vertex'].data.copy()
    print(points.shape)
    cloud = np.empty([6513005, 3])
    for i in range(len(points)):
        point = points[i]
        p = np.array([point[0], point[1], point[2]])
        cloud[i] = p
    return np.array(cloud)

out_arr = read_ply_cloud('D:\点云三维检索\SHREC14/test.ply')

批量操作的方法

import numpy as np
from plyfile import PlyData
import open3d
import os


old_names = os.listdir('D:\\SHREC14/OFF')
for old_name in old_names:  # 遍历列表下的文件名
    input_path='D:\\SHREC14/OFF/'+old_name
    file_name, extension = os.path.splitext(old_name)
    s1 = file_name[-6:]
    print(s1)
    output_path='D:\\SHREC14\PLY/'+file_name+'.ply'
    to_ply(input_path, output_path, 'off')
    ply_data = PlyData.read(output_path)
    points = ply_data['vertex'].data.copy()
    cloud = []
    for i in range(len(points)):
        point = points[i]
        p = np.array([point[0], point[1], point[2]])
        cloud.append(p)
    a=np.array(cloud)
    b=a.shape[0]

    if b>2055:#因为有的模型转化成的点云数量太少了
        np.savetxt(r'D:\\SHREC14\TXT/'+file_name+'.txt', a, fmt='%d')


诸君共勉!

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值