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

        手把手帶你通過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號
        主站蜘蛛池模板: 日韩精品免费在线视频| 国产一级精品高清一级毛片| 久久精品国产秦先生| 在线观看国产精品普通话对白精品 | 国产女主播精品大秀系列| 国产精品成人99久久久久91gav| 国产精品H片在线播放| 国产精品白丝AV网站| 亚洲国产精品毛片av不卡在线 | 99热门精品一区二区三区无码| 久久亚洲国产欧洲精品一| 麻豆成人久久精品二区三区免费| 国产夫妇精品自在线| 久久99精品久久久久久久不卡| 91精品国产91久久久久久青草| 高清在线亚洲精品国产二区| 99视频精品全部在线观看| 亚洲精品麻豆av| 黑巨人与欧美精品一区| 亚洲精品国产成人专区| 国产成人精品日本亚洲直接| 久久久久人妻一区精品性色av| 影视网欧洲精品| HEYZO无码综合国产精品227| 欧美肥屁VIDEOSSEX精品| 亚洲av永久无码精品网站| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 牛牛在线精品观看免费正| 国产精品欧美一区二区三区 | 天天视频国产精品| 精品一区二区三区在线观看| 1区1区3区4区产品芒果精品| 欧美精品/日韩精品/国产精品| 中文精品久久久久人妻| 亚洲精品欧美精品日韩精品| 久久久久久久久久久免费精品| 国产午夜精品无码| 国产精品va无码一区二区| 国产精品无码无片在线观看| 国产精品v片在线观看不卡| 国产精品亚洲日韩欧美色窝窝色欲 |