笔者用到了人脸数据集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'])