站長資訊網
        最全最豐富的資訊網站

        手把手帶你通過Python調用接口實現摳圖并改底色

        手把手帶你通過Python調用接口實現摳圖并改底色

        程序員必備接口測試調試工具:立即使用
        Apipost = Postman + Swagger + Mock + Jmeter
        Api設計、調試、文檔、自動化測試工具
        后端、前端、測試,同時在線協作,內容實時同步

        有時候我們的證件照需要換底色,又來不及去照相館拍照,用ps也不好摳圖,所以今天給你們分享一下如何用python來摳圖,并換底色

        一、注冊百度AI賬號,創建人像分割應用

        • 百度人像分割主頁:按步驟注冊,登錄,實名認證即可。

        • 在控制臺主頁找到人體分析

        手把手帶你通過Python調用接口實現摳圖并改底色

        創建應用

        手把手帶你通過Python調用接口實現摳圖并改底色

        里面的需要填寫的內容可以隨便寫,新用戶要去領取免費資源,不然使用不了。

        手把手帶你通過Python調用接口實現摳圖并改底色

        創建完成在應用列表記錄 API Key、Secret Key的值 ,稍后要用。

        手把手帶你通過Python調用接口實現摳圖并改底色

        至此,注冊賬號和創建應用的任務就完成了。

        手把手帶你通過Python調用接口實現摳圖并改底色

        二、代碼實現

        1.引入庫

        import os import requests import base64 import cv2 import numpy as np from PIL import Image from pathlib import Path  path = os.getcwd() paths = list(Path(path).glob('*'))
        登錄后復制

        2.獲取Access Token

        def get_access_token():     url = 'https://aip.baidubce.com/oauth/2.0/token'     data = {         'grant_type': 'client_credentials',  # 固定值         'client_id': '替換成你的API Key',  # 在開放平臺注冊后所建應用的API Key         'client_secret': '替換成你的Secret Key'  # 所建應用的Secret Key     }     res = requests.post(url, data=data)     res = res.json()     access_token = res['access_token']     return access_token
        登錄后復制

        核心代碼

        對文章有問題可以私信我或者來這里哦 https://jq.qq.com/?_wv=1027&k=s5bZE0K3

        def removebg():     try:         request_url = "https://aip.baidubce.com/rest/2.0/image-classify/v1/body_seg"         # 二進制方式打開圖片文件         f = open(name, 'rb')         img = base64.b64encode(f.read())         params = {"image":img}         access_token = get_access_token()         request_url = request_url + "?access_token=" + access_token         headers = {'content-type': 'application/x-www-form-urlencoded'}         response = requests.post(request_url, data=params, headers=headers)         if response:             res = response.json()["foreground"]             png_name=name.split('.')[0]+".png"             with open(png_name,"wb") as f:                 data = base64.b64decode(res)                 f.write(data)             fullwhite(png_name) #png圖片底色填充,視情況舍去             png_jpg(png_name) #png格式轉jpg,視情況舍去             os.remove(png_name) #刪除原png圖片,視情況舍去             print(name+"t處理成功!")     except Exception as e:         pass
        登錄后復制

        4.圖片底色填充

        def fullwhite(png_name):     im = Image.open(png_name)     x,y = im.size     try:         p = Image.new('RGBA', im.size, (255,255,255))        # 使用白色來填充背景,視情況更改         p.paste(im, (0, 0, x, y), im)         p.save(png_name)     except:         pass
        登錄后復制

        5.圖片壓縮

        #compress_rate:數值越小照片越模糊 def resize(compress_rate = 0.5):     im = Image.open(name)     w, h = im.size     im_resize = im.resize((int(w*compress_rate), int(h*compress_rate)))     resize_w, resieze_h = im_resize.size     #quality 代表圖片質量,值越低越模糊     im_resize.save(name)     im.close()
        登錄后復制

        6.獲取圖圖片大小

        def get_size():     size = os.path.getsize(name)     return size / 1024
        登錄后復制

        7.png格式轉jpg

        def png_jpg(png_name):     im = Image.open(png_name)     bg=Image.new('RGB',im.size,(255,255,255))     bg.paste(im)     jpg_name = png_name.split('.')[0]+".jpg"     #quality 代表圖片質量,值越低越模糊     bg.save(jpg_name,quality=70)     im.close()
        登錄后復制

        8.主函數

        if __name__ == '__main__':     for i in paths:         name = os.path.basename(i.name)         if(name==os.path.basename(__file__)):             continue         size = get_size()         ##照片壓縮         while size >=900:             size = get_size()             resize()            removebg()         print(" ")
        登錄后復制

        9.完整代碼

        對文章有問題可以私信我或者來這里哦 https://jq.qq.com/?_wv=1027&k=s5bZE0K3

        #人像分割 import os import requests import base64 import cv2 import numpy as np from PIL import Image from pathlib import Path  path = os.getcwd() paths = list(Path(path).glob('*'))  def get_access_token():     url = 'https://aip.baidubce.com/oauth/2.0/token'     data = {         'grant_type': 'client_credentials',  # 固定值         'client_id': '替換成你的API Key',  # 在開放平臺注冊后所建應用的API Key         'client_secret': '替換成你的Secret Key'  # 所建應用的Secret Key     }     res = requests.post(url, data=data)     res = res.json()     access_token = res['access_token']     return access_token def png_jpg(png_name):     im = Image.open(png_name)     bg=Image.new('RGB',im.size,(255,255,255))     bg.paste(im)     jpg_name = png_name.split('.')[0]+".jpg"     #quality 代表圖片質量,值越低越模糊     bg.save(jpg_name,quality=70)     im.close()  #compress_rate:數值越小照片越模糊 def resize(compress_rate = 0.5):     im = Image.open(name)     w, h = im.size     im_resize = im.resize((int(w*compress_rate), int(h*compress_rate)))     resize_w, resieze_h = im_resize.size     #quality 代表圖片質量,值越低越模糊     im_resize.save(name)     im.close()      def get_size():     size = os.path.getsize(name)     return size / 1024      def fullwhite(png_name):     im = Image.open(png_name)     x,y = im.size     try:         # 使用白色來填充背景         # (alpha band as paste mask).         p = Image.new('RGBA', im.size, (255,255,255))         p.paste(im, (0, 0, x, y), im)         p.save(png_name)     except:         pass  def removebg():     try:         request_url = "https://aip.baidubce.com/rest/2.0/image-classify/v1/body_seg"         # 二進制方式打開圖片文件         f = open(name, 'rb')         img = base64.b64encode(f.read())         params = {"image":img}         access_token = get_access_token()         request_url = request_url + "?access_token=" + access_token         headers = {'content-type': 'application/x-www-form-urlencoded'}         response = requests.post(request_url, data=params, headers=headers)         if response:             res = response.json()["foreground"]             png_name=name.split('.')[0]+".png"             with open(png_name,"wb") as f:                 data = base64.b64decode(res)                 f.write(data)             fullwhite(png_name)             png_jpg(png_name)             os.remove(png_name)             print(name+"t處理成功!")     except Exception as e:         pass  if __name__ == '__main__':     for i in paths:         name = os.path.basename(i.name)         if(name==os.path.basename(__file__)):             continue         size = get_size()         ##照片壓縮         while size >=900:             size = get_size()             resize()            removebg()         print(" ")
        登錄后復制

        [重要]使用前注意事項

        1. 該程序會覆蓋原文件,使用前請備份文件,以免造成數據丟失
        2. 將程序復制到和待處理的照片同目錄下,雙擊程序即可運行

        手把手帶你通過Python調用接口實現摳圖并改底色

        最終效果圖

        原圖:

        手把手帶你通過Python調用接口實現摳圖并改底色
        效果圖

        手把手帶你通過Python調用接口實現摳圖并改底色

        總結

        代碼不算難,就是中途有許多小問題,比如圖片大小不能超過4MB,就得壓縮照片,路徑之類的問題,總之實現了這個功能很開心!

        好啦,今天的分享到這里就結束了 ~

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 久久久久这里只有精品| 亚洲AV永久无码精品| 惠民福利中文字幕人妻无码乱精品| 无码人妻精品一区二区三区久久久 | 91探花国产综合在线精品| 亚洲av午夜福利精品一区| 国产精品99久久久久久宅男| 久久精品国产亚洲AV麻豆网站| 日韩欧美国产精品第一页不卡 | 真实国产乱子伦精品一区二区三区| 91精品国产色综久久| 成人午夜精品网站在线观看| 欧美精品久久久久久久自慰| 日韩精品无码永久免费网站| 久久99国产精品成人欧美| 一区二区三区日韩精品| 国产精品欧美一区二区三区不卡| 久久久一本精品99久久精品88| 中文字幕精品无码久久久久久3D日动漫 | 国产大片91精品免费观看不卡| 亚洲国产精品无码久久久不卡 | 国产精品国产三级国产AⅤ| 久久国产精品一区二区| 国产精品jizz视频| 精品国产福利一区二区| 精品无码av一区二区三区| 日韩精品无码一区二区三区免费 | 国产精品片在线观看手机版| 久久精品国产亚洲沈樵| 精品视频一区二区三区在线观看 | 精品无码国产自产拍在线观看| 中文字幕在线精品视频入口一区| 老司机精品影院91| 蜜臀AV无码国产精品色午夜麻豆| 精品无码国产自产拍在线观看蜜| 国产女人18毛片水真多18精品| 国产精品激情综合久久| 国产精品免费αv视频| 国精品无码A区一区二区| 国产亚洲精品无码专区| 老湿亚洲永久精品ww47香蕉图片|