Python用5行代碼實(shí)現(xiàn)批量摳圖的示例代碼
前言
對于會(huì)PhotoShop的人來說,摳圖是非常簡單的操作了,有時(shí)候幾秒鐘就能扣好一張圖。不過一些比較復(fù)雜的圖,有時(shí)候還是要畫點(diǎn)時(shí)間的,今天就給大家?guī)Я艘粋€(gè)非常快速簡單的辦法,用Python來批量摳取人像。
效果展示
開始吧,我也不看好什么自動(dòng)摳圖,總覺得不夠精確,摳不出滿意的圖。下面我就直接展示一下效果圖吧。我們先看看原圖

這張圖片背景未純色,我們平時(shí)用PhotoShop摳起來也比較簡單,對我們計(jì)算機(jī)來說也不是什么難題,下面是效果圖:

因?yàn)楸旧硎荘NG圖片,而且原圖是白色背景,所以看不出什么區(qū)別。為了顯示效果,我把原圖和摳好的圖放到一張黃色背景圖片上:

這樣一看效果明顯多了,感覺摳圖效果還是非常好的。但是吧,摳這種簡單的圖片,不怎么過癮,我們再來看看復(fù)雜一點(diǎn)的圖片:

這張圖片背景色比之前復(fù)雜一些,而且有漸變,我們來看看摳圖后的效果如何:

這個(gè)原圖背景不是白色,我就不弄黃色背景了,趕緊這個(gè)效果也還算滿意,那么多人物的圖片呢,我們再看看下面這張圖片:

這里有三個(gè)人,我們看看程序能不能自動(dòng)摳出來:

雖然是有點(diǎn)瑕疵,不過還是很不錯(cuò)了,下面我們看看最后一個(gè)例子:

這個(gè)就比前面的都復(fù)雜的多,那么效果如何呢,我們來看看:

哈哈,不僅識別出了人,還把火炬識別出來并摳了出來。總的來說,在完成人物摳圖方面還是沒有什么問題的。
環(huán)境
看完效果,那么應(yīng)該怎么實(shí)現(xiàn)呢?這就需要用到paddlepaddle了,那paddlepaddle是什么呢?paddlepaddle是一個(gè)開源的深度學(xué)習(xí)工具,我們使用該工具可以僅用十幾行代碼實(shí)現(xiàn)遷移學(xué)習(xí)。在使用之前,我們先來安裝paddlepaddle,我們可以進(jìn)入官網(wǎng)https://www.paddlepaddle.org.cn/,官網(wǎng)上用安裝指引。為了方便,這里直接使用pip安裝CPU版本的。我們執(zhí)行下列語句:
python -m pip install paddlepaddle -i https://mirror.baidu.com/pypi/simple
安裝完成后我們可以在環(huán)境中測試一下是否成功。我這里使用命令行窗口,先運(yùn)行python.exe(前提是你已經(jīng)配置了環(huán)境變量)
C:Userszaxwz>python
然后在程序中運(yùn)行如下代碼:
Python 3.7.6 (tags/v3.7.6:43364a7ae0, Dec 19 2019, 00:42:30) [MSC v.1916 64 bit (AMD64)] on win32Type 'help', 'copyright', 'credits' or 'license' for more information.>>> import paddle.fluid>>> paddle.fluid.install_check.run_check()
如果控制臺顯示Your Paddle is installed successfully! Let’s start deep Learning with Paddle now就代表我們已經(jīng)安裝成功了。另外我們還需要安裝paddlehub:
pip install -i https://mirror.baidu.com/pypi/simple paddlehub
下面我們就可以開始寫代碼了。
實(shí)現(xiàn)摳圖
實(shí)現(xiàn)摳圖的代碼很簡單,大概分為下面幾個(gè)步驟:
導(dǎo)入模塊 加載模型 獲取文件列表 摳圖實(shí)現(xiàn)起來沒有什么難度,為了方便讀代碼,我將代碼寫清楚一點(diǎn):
# 1、導(dǎo)入模塊import osimport paddlehub as hub# 2、加載模型humanseg = hub.Module(name=’deeplabv3p_xception65_humanseg’)# 3、獲取文件列表# 圖片文件的目錄path = ’D:/CodeField/Workplace/PythonWorkplace/PillowTest/11_yellow/img/’# 獲取目錄下的文件files = os.listdir(path)# 用來裝圖片的imgs = []# 拼接圖片路徑for i in files: imgs.append(path + i)#摳圖results = humanseg.segmentation(data={’image’:imgs})
我們在控制臺運(yùn)行一下這個(gè)程序:
D:CodeFieldWorkplacePythonWorkplacePillowTest11_yellow>python 摳圖.py[2020-03-10 21:42:34,587] [ INFO] - Installing deeplabv3p_xception65_humanseg module[2020-03-10 21:42:34,605] [ INFO] - Module deeplabv3p_xception65_humanseg already installed in C:Userszaxwz.paddlehubmodulesdeeplabv3p_xception65_humanseg[2020-03-10 21:42:35,472] [ INFO] - 0 pretrained paramaters loaded by PaddleHub
運(yùn)行完成后,我們可以在項(xiàng)目下看到humanseg_output目錄,摳好的圖片就會(huì)存放在該目錄下。當(dāng)然了,上面的代碼我們在獲取文件列表的操作還可以簡化一下:
import os, paddlehub as hubhumanseg = hub.Module(name=’deeplabv3p_xception65_humanseg’)# 加載模型path = ’D:/CodeField/Workplace/PythonWorkplace/PillowTest/11_yellow/img/’# 文件目錄files = [path + i for i in os.listdir(path)]# 獲取文件列表results = humanseg.segmentation(data={’image’:files})# 摳圖
到此這篇關(guān)于Python用5行代碼實(shí)現(xiàn)批量摳圖的示例代碼的文章就介紹到這了,更多相關(guān)Python 批量摳圖內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. python文件處理--文件讀寫詳解2. 新手學(xué)python應(yīng)該下哪個(gè)版本3. 詳細(xì)總結(jié)Java for循環(huán)的那些坑4. Python通過format函數(shù)格式化顯示值5. python對批量WAV音頻進(jìn)行等長分割的方法實(shí)現(xiàn)6. jsp文件下載功能實(shí)現(xiàn)代碼7. uni-app結(jié)合PHP實(shí)現(xiàn)單用戶登陸demo及解析8. 如何利用Python matplotlib繪制雷達(dá)圖9. ajax實(shí)現(xiàn)頁面的局部加載10. 詳解CSS偽元素的妙用單標(biāo)簽之美

網(wǎng)公網(wǎng)安備