python读取mat_【Python】Python读取mat数据集(COFW,300WLP),解析后训练模型用

本文记录如何使用Python读取MATLAB生成的COFW和300WLP人脸数据集。通过scipy.io.loadmat方法处理7.3以上版本的mat文件,提取landmarks并转换为numpy格式。对于COFW数据集,使用h5py库读取,并展示图片与landmarks。
摘要由CSDN通过智能技术生成

笔者用到了人脸数据集COFW,300WLP,但文件都是mat文件,也搜了下资料,最终调通完美运行,这里记录下

Python读取文件的方式主要有两种:

由于mat文件是有MATLAB生成的,所以 7.3 以上的用方法2,版本7.3以下的用方法1,反之会报错!

方法1: from scipy.io import loadmat

mat_path是mat文件的路径,格式为字符串

路径格式:

‘/media/cxx/AEDAFE58DAFE1BF11/lcswork/align_dataset/300W-LP/300W-LP/300W_LP/AFW/AFW_1051618982_1_0.mat’

c_mat = loadmat(mat_path)

打印下keys()

print(c_mat.keys())

输出结果

#dict_keys(['__header__', '__version__', '__globals__', 'pt2d', 'roi',

# 'Illum_Para', 'Color_Para', 'Tex_Para', 'Shape_Para', 'Exp_Para', 'Pose_Para'])

这里想要获取,landmarks,先用 c_mat[‘pt2d’]得到值,再transpose,将矩阵转置,再转化成numpy格式后,再做reshape,就是想到的成对的坐标

landmarks = np.array(np.transpose(c_mat['pt2d'])

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值