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

        手把手帶你通過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號
        主站蜘蛛池模板: 国内精品91最新在线观看| 亚洲无删减国产精品一区| 国产成人久久精品区一区二区| 国产亚洲色婷婷久久99精品91 | 国产亚洲精品资在线| 国产成人精品日本亚洲专一区 | 亚洲国产精品久久| 国产精品多人p群无码| 亚洲精品无码专区在线在线播放| 精品久久久久久无码中文字幕 | 日韩精品视频在线观看免费| 91精品视频在线| 精品999久久久久久中文字幕 | 亚洲国产成人久久精品99 | www.亚洲精品| 久久精品无码专区免费东京热| 亚洲精品人成无码中文毛片| 精品久久国产一区二区三区香蕉| 在线欧美v日韩v国产精品v| 国产精品欧美久久久天天影视| 精品国偷自产在线| 久久精品人人做人人爽电影蜜月| 亚洲精品二三区| 香蕉99久久国产综合精品宅男自| 久久亚洲国产精品五月天婷| 精品少妇一区二区三区在线| 精品国产乱码久久久久久浪潮| 精品水蜜桃久久久久久久| 久久93精品国产91久久综合| 国产人成精品综合欧美成人| 国产精品性爱| 国产亚洲精品国看不卡| 国产一区二区三区精品视频| 国产色婷婷精品综合在线| 国产在线观看高清精品| 国语自产精品视频在线观看| 蜜臀av无码人妻精品| 亚洲精品成人网久久久久久| 亚洲综合av永久无码精品一区二区 | 成人区精品一区二区不卡| 东京热TOKYO综合久久精品|