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

        手把手帶你通過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號
        主站蜘蛛池模板: 97在线精品视频| 国产在线精品一区免费香蕉 | 国产伦精品一区二区三区视频猫咪 | 永久免费精品影视网站| 久久精品国产亚洲沈樵| 国产精品亚洲а∨无码播放 | 亚洲国产人成精品| 精品多毛少妇人妻AV免费久久| 久久福利青草精品资源站免费| 国产在线精品一区二区在线观看 | 56prom精品视频在放免费| 国产精品9999久久久久| 人妻少妇精品视频二区| 亚洲AV永久无码精品成人| 日本精品一区二区三区在线视频一 | 欧美精品区一级片免费播放| 国产乱人伦偷精品视频 | 最新精品露脸国产在线 | 久久久精品无码专区不卡| 2023国产精品自拍| 热99re久久国超精品首页 | 国产精品久久亚洲不卡动漫| 国产精品熟女一区二区| 久久99精品久久久久久久不卡 | 亚洲精品无码激情AV| 欧美在线精品一区二区三区 | 亚洲精品97久久中文字幕无码| 蜜桃麻豆www久久国产精品 | 亚洲αv在线精品糸列| 亚洲国产精品一区第二页| 午夜精品射精入后重之免费观看| 亚洲精品岛国片在线观看| 伊人久久大香线蕉精品不卡| 亚洲精品卡2卡3卡4卡5卡区| 正在播放国产精品每日更新 | 久久r热这里有精品视频| 久久国产精品久久久| 亚洲国产精品久久久久久| 色综合久久综精品| 国产精品内射久久久久欢欢| 精品无码专区亚洲|