不到 100 行 Python 代码即可实现换脸功能

本篇介绍的换脸方法我们借助于第三方 Face++的API 来实现,我们通过的 API 接口提供方是 Face++官网,首先我们需要到该网站注册一个自己的账号。

Face++官网:https://console.faceplusplus.com.cn/register

打开后如下所示:
在这里插入图片描述

我们可以通过手机号和邮箱两种方式来注册,注册好账号之后,我们再进行登录,登录之后,我们要找到API Key点进去,如下图所示:

在这里插入图片描述

点击创建API Key进去

在这里插入图片描述

里面东西可以随便填写(正式的要钱,测试玩玩用试用就好)

在这里插入图片描述

创建之后就有api_key和api_secret了

在这里插入图片描述

有api_key和api_secret后,我们将下面的代码写入pycharm解释器里面,如果没有安装的可以看我之前的文章:最详细的anaconda+python+pycharm安装

代码如下:

import requests, simplejson, json, base64
    # 获取人脸关键点
def find_face(imgpath):
    print("正在查找……")
    http_url = "https://api-cn.faceplusplus.com/facepp/v3/detect"

    data = {"api_key": "xxxxx",  ##替换掉‘你的api_key’,不要删除双引号,下面同理
            "api_secret": "xxxxx",##替换掉‘你的api_secret’
            "image_url": imgpath, "return_landmark":1}

    files = {"image_file": open(imgpath, "rb")}
    response = requests.post(http_url, data=data, files=files)
    req_con = response.content.decode('utf-8')
    req_dict = json.JSONDecoder().decode(req_con)
    this_json = simplejson.dumps(req_dict)

    this_json2 = simplejson.loads(this_json)
    #print(this_json2)
    faces = this_json2['faces']
    list0 = faces[0]
    rectangle = list0['face_rectangle']
    # print(rectangle)
    return rectangle
    # 换脸,图片的大小应不超过 2M,number 表示换脸的相似度
def merge_face(image_url1, image_url2, image_url, number):
    ff1 = find_face(image_url1)
    ff2 = find_face(image_url2)
    rectangle1 = str(str(ff1['top']) + "," + str(ff1['left']) + "," + str(ff1['width']) + "," + str(ff1['height']))
    rectangle2 = str(ff2['top']) + "," + str(ff2['left']) + "," + str(ff2['width']) + "," + str(ff2['height'])
    print(rectangle2)
    url_add = "https://api-cn.faceplusplus.com/imagepp/v1/mergeface"
    f1 = open(image_url1, 'rb')
    f1_64 = base64.b64encode(f1.read())
    f1.close()
    f2 = open(image_url2, 'rb')
    f2_64 = base64.b64encode(f2.read())
    f2.close()

    data = {"api_key": "xxxxx", ##替换掉‘你的api_key’
            "api_secret": "xxxxxx",##替换掉‘你的api_secret’
            "template_base64": f1_64, "template_rectangle": rectangle1,
            "merge_base64": f2_64, "merge_rectangle": rectangle2, "merge_rate": number}

    response = requests.post(url_add, data=data)
    req_con1 = response.content.decode('utf-8')
    req_dict = json.JSONDecoder().decode(req_con1)
    result = req_dict['result']
    imgdata = base64.b64decode(result)
    file = open(image_url, 'wb')
    file.write(imgdata)
    file.close()

image1 = r"1.jpg"  ##原始照片1的路径,若为/.png格式则将‘jpg’改为‘png’,下面同理
image2 = r"1.png"   ##原始照片2的路径;→将照片1 的五官加在照片2上;
image = r"新生成图片.jpg"  ##生成的新照片

merge_face(image2, image1, image, 90)

记得替换调里面的api_key和api_secret记得替换

效果如下:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

以上所述是小编给大家介绍的python代码实现换脸功能,大家可以多多尝试,有可能有一些脸部是不太能对上的。希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。

  • 0
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
实现图片功能,可以使用 Python 的 PIL 库和 dlib 库。下面是一个简单的 Python 代码示例: ```python import dlib import numpy as np from PIL import Image # 加载模型 predictor_path = 'shape_predictor_68_face_landmarks.dat' detector = dlib.get_frontal_face_detector() predictor = dlib.shape_predictor(predictor_path) # 读取两张图片 img1 = Image.open('image1.jpg') img2 = Image.open('image2.jpg') # 将图片转为 numpy 数组 img1_arr = np.array(img1) img2_arr = np.array(img2) # 检测人 faces1 = detector(img1_arr, 1) faces2 = detector(img2_arr, 1) # 获取人关键点 landmarks1 = predictor(img1_arr, faces1[0]) landmarks2 = predictor(img2_arr, faces2[0]) # 将关键点转为 numpy 数组 landmarks1_arr = np.array([[p.x, p.y] for p in landmarks1.parts()]) landmarks2_arr = np.array([[p.x, p.y] for p in landmarks2.parts()]) # 计算变矩阵 transformation_matrix, _ = cv2.estimateAffinePartial2D(landmarks2_arr, landmarks1_arr) # 为图片2应用变矩阵 img2_transformed = cv2.warpAffine(img2_arr, transformation_matrix, (img1_arr.shape[1], img1_arr.shape[0]), flags=cv2.INTER_LINEAR, borderMode=cv2.BORDER_REFLECT) # 将 numpy 数组转为图片并保存 result = Image.fromarray(img2_transformed) result.save('result.jpg') ``` 需要注意的是,这只是一个简单的代码示例,实际使用时可能需要对代码一些修改和优化。另外,为了代码正常运,需要下载 dlib 库和人关键点检测模型文件(shape_predictor_68_face_landmarks.dat),并将其放置在代码所在的目录中。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

准时准点睡觉

如果觉得不错可以点点这里哦

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值