【计算机视觉】使用python dlib做人脸68点对齐

该博客介绍如何使用Python的dlib库读取文件夹内的图片,并通过预训练的shape_predictor_68_face_landmarks.dat模型进行人脸68点对齐,将结果保存为PTS文件。每个PTS文件包含68个关键点坐标,用于后续的人脸分析或处理。
摘要由CSDN通过智能技术生成

使用python dlib做人脸68点对齐,读取文件夹内image,输出到同目录下同名pts文件
不多说

import os
import dlib
from skimage import io

def landmark_helper(data_dir):

    predictor_path = "model/shape_predictor_68_face_landmarks.dat"

    face_paths= os.listdir(data_dir)

    for path in face_paths:
        face_path = data_dir + path
        '''加载人脸检测器、加载官方提供的模型构建特征提取器'''
        detector = dlib.get_frontal_face_detector()
        predictor = dlib.shape_predictor(predictor_path)

        img = io.imread(face_path)

        dets = detector(img, 1)

        if (len(dets) != 1):
            print('Illegal facial image : ' + face_path + ', detected ' + len(dets) + 'face(s), need 1 !')

        pts_path = face_path.split('.')[0] + '.pts'

        with open(pts_path, mode='w', encoding='utf-8') as file_obj:
            file_obj.write('version: 1\n')
            file_obj.write('n_points:  68\n')
            file_obj.write('{\n')

            for k, d in enumerate(dets):
                shape = predictor(img, d) 
                for p in shape.parts():
                    file_obj.write(str(p.x) + ' ' + str(p.y) + '\n')

            file_obj.write('}\n')

shape_predictor_68_face_landmarks.dat很多地方可以下载,这里贴一个可以下载的gitHub地址

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值