ASCII码 ASCII码

Python图片批量自动抠图去背景

发布于:2022-03-16 08:47:44  栏目:技术文档

图片批量自动抠图去背景

今天发现个好东西啊,叫片刻抠图(pickwant.com),是一个在线对图片自动抠图去除背景的网站。只要上传图片,就可以自动把背景去掉把目标对象抠出来。

不管是动物、汽车或各种产品,还是人物,都可以全自动做到令人惊艳的抠图效果!而且还说可以做到发丝级 AI 自动抠图,作为一个头发存留不多的程序员,突然莫名感觉到一丝来自这个世界的恶意。

这个抠图有什么用?比如可以把人物抠出来换个背景:

也可以把产品抠出来做成新的商品宣传图:(做电商的朋友肯定懂)

这么好用的东西,现在最关键的是:完全免费!

emmmmmm,这个消息被我的几十个前任女友知道了,她们纷纷发来照片,要我给她把照片背景给去掉,把她美美的人像给抠出来,之后好换上马尔代夫的背景。

这么多的图片要一张张传上去,再下载回来,同样的事情做几十遍那我肯定不会做的。

那么,必须要写个 Python 自动化脚本程序来搞定了。

说干就干,二话不说就掏出网页自动化的神器 Selenium,写简单几行代码:

  1. """
  2. Selenium是第三方库,需要先安装,在Teminal里执行:pip install selenium
  3. 驱动程序 chromedriver 需要根据浏览器 chrome 的版本下载
  4. 有问题的可以加我:youbafu (全网统一id)
  5. """
  6. from selenium import webdriver
  7. from selenium.webdriver.chrome.service import Service
  8. s = Service(r'D:\driver\chromedriver.exe')
  9. # 初始化浏览器为chrome浏览器
  10. browser = webdriver.Chrome(service=s)
  11. # 打开 片刻抠图
  12. browser.get(r'https://www.pickwant.com')

就完成了自动打开网页:

但这是远远不够的,我们需要实现自动上传图片,然后自动下载。

通过几次手动操作得出规律,我们只要进入到编辑界面

然后循环执行以下步骤:

1、点击网页右上角的重新上传按钮。

2、选择要上传的图片,点打开按钮。

3、等几秒抠好图后,点网页右上角下载按钮。

4、弹出对话框后,再点 确认下载就会自动保存图片。

就可以依次把文件夹里的前女友们的图片完成自动抠图了。

要做出自动化脚本,接下来就是找到这些按钮,然后模拟点击就可以了。在重新下载按钮上点鼠标右键,在弹出的菜单中点检查,弹出了网页的元素查看界面,再重复操作一次,就定位到了这个按钮的网页代码:

可以看到重新上传是个 span ,这里可以取它的上级 div,它的class是 border_wrap upload_wrap ,那么就可以写代码定位到这个元素,然后执行 click() 操作了。

  1. import time
  2. from selenium import webdriver
  3. from selenium.webdriver.chrome.service import Service
  4. from selenium.webdriver.common.by import By
  5. s = Service(r'D:\driver\chromedriver.exe')
  6. # 初始化浏览器为chrome浏览器
  7. browser = webdriver.Chrome(service=s)
  8. # 打开 片刻抠图
  9. browser.get(r'https://www.pickwant.com/#/editor')
  10. time.sleep(1)
  11. # 定位到 重新上传 按钮
  12. upload = browser.find_element(By.CSS_SELECTOR, '.border_wrap.upload_wrap')
  13. upload.click()

这里要特别说明的是,根据 CSS 的基本语法,id用#表示,class用.来表示,如果中间有空格也是用.来拼接,下级标签用>来拼接。

  1. <div data-v-0373fdbc="" class="border_wrap upload_wrap"></div>

对于这样的 div 标签,其class是 border_wrap upload_wrap ,所以 By.CSS_SELECTOR 的查找元素的参数就是 ‘.border_wrap.upload_wrap’ 。

代码执行后,弹出一个选择文件的对话框:

这时候问题来了,这个对话框是 Windows 系统级别的,不受Selenium控制,怎么办?

不要慌,这难不倒霸夫老师,既然是 Windows 系统弹窗,那总得受系统控制吧!

那就祭出 pywin32 库来对付它,在终端命令行(Terminal)里输入命令安装库:

  1. pip install pywin32

然后再打开查看 Windows 窗口信息的神器 spy++,拿到窗口的类名和层次结构关系,就可以写出以下的自动选择文件并点击按钮的函数代码了:

  1. import win32con # win32库里包含了很多模块
  2. import win32gui # 这里导入具体用到的模块
  3. def 上传图片(文件路径):
  4. dialog = win32gui.FindWindow('#32770', u'打开') # 对话框
  5. ComboBoxEx32 = win32gui.FindWindowEx(dialog, 0, 'ComboBoxEx32', None)
  6. ComboBox = win32gui.FindWindowEx(ComboBoxEx32, 0, 'ComboBox', None)
  7. Edit = win32gui.FindWindowEx(ComboBox, 0, 'Edit', None) # 上面三句依次寻找对象,直到找到输入框Edit对象的句柄
  8. button = win32gui.FindWindowEx(dialog, 0, 'Button', None) # 打开按钮
  9. time.sleep(0.5)
  10. win32gui.SendMessage(Edit, win32con.WM_SETTEXT, None, 文件路径) # 往输入框输入绝对地址
  11. time.sleep(0.5)
  12. win32gui.SendMessage(dialog, win32con.WM_COMMAND, 1, button) # 点 打开 按钮
  13. time.sleep(5)

先写好这个函数备用,等下要上传哪张图片,只要调用函数时把图片的文件路径作为参数传入,就可以完成目标了。

上传图片后,只要稍等一两秒就自动完成抠图了。这时候再点网页右上角下载按钮,等弹出对话框后,再点 确认下载就会自动保存图片。

前面我们学习了定位元素的方法了,再定位这两个按钮对我们来说不是什么困难了。

但是,你都能坚持看到这里了,霸夫老师必须要教你个更牛X的更方便的技巧了:

在下载按钮上点鼠标右键,在弹出的菜单中点检查,弹出了网页的元素查看界面,再重复操作一次,就定位到了这个按钮的网页代码。然后在它的上一级的这个div标签上点鼠标右键,选择Copy,再选择 Copy selector。

然后回到python代码编辑窗口,粘贴就可以获得准确的定位参数:

  1. #app > div > div:nth-child(1) > div.col-md-12.wonx_row.top_bar > div.border_wrap.download_wrap

这样就省去了辛辛苦苦去理解和转化参数,大大提高效率,接下来就可以轻松写出定位元素和点击的代码:

  1. download = browser.find_element(By.CSS_SELECTOR, '#adownload = browser.find_element(By.CSS_SELECTOR, '#app > div > div:nth-child(1) > div.col-md-12.wonx_row.top_bar > div.border_wrap.download_wrap')
  2. download.click() # 点击 下载
  3. time.sleep(0.5)
  4. comfirm = browser.find_element(By.CSS_SELECTOR, '#app > div > div.container > div.dialog-content > div > div.download_wrap')
  5. comfirm.click() # 点击 确认下载
  6. time.sleep(1)pp > div > div:nth-child(1) > div.col-md-12.wonx_row.top_bar > div.border_wrap.download_wrap')
  7. download.click() # 点击 下载
  8. time.sleep(0.5)
  9. comfirm = browser.find_element(By.CSS_SELECTOR, '#app > div > div.container > div.dialog-content > div > div.download_wrap')
  10. comfirm.click() # 点击 确认下载
  11. time.sleep(1)

单张图片的上传和下载流程都写完了,接下来要写个获取文件夹下所有图片的函数,来实现依次把每个前任的图片都完成抠图的任务。

我把她们的照片都放在电脑的 E: 盘下的前任女友这个文件夹里,那么只要读取这个文件夹下的所有图片,依次执行执行一遍上传和下载操作就可以了。

  1. 文件夹路径 = r'E:\前任女友'
  2. names = os.listdir(文件夹路径) # 列举出该目录下所有的文件名
  3. for name in names:
  4. path = os.path.join(文件夹路径, name) # 拼接出图片完整路径
  5. # 点击重新上传() # 等待封装
  6. 上传图片(path)
  7. # 点击下载() # 等待封装

所有的逻辑都理清楚了,模块也基本写好了,接下来就把代码整合一下,来看完整代码:

  1. """
  2. 片刻抠图
  3. 图片批量自动抠图去背景
  4. 作者:有霸夫
  5. 有问题请加vx:youbafu
  6. """
  7. import time
  8. from selenium import webdriver
  9. from selenium.webdriver.chrome.service import Service
  10. from selenium.webdriver.common.by import By
  11. import win32con
  12. import win32gui
  13. import os
  14. s = Service(r'D:\driver\chromedriver.exe')
  15. # 初始化浏览器为chrome浏览器
  16. browser = webdriver.Chrome(service=s)
  17. # 打开 片刻抠图
  18. browser.get(r'https://www.pickwant.com')
  19. time.sleep(1)
  20. browser.get(r'https://www.pickwant.com/#/editor')
  21. time.sleep(2)
  22. def 点击重新上传():
  23. while True:
  24. try:
  25. # 定位到 重新上传 按钮
  26. upload = browser.find_element(By.CSS_SELECTOR, '.border_wrap.upload_wrap')
  27. upload.click()
  28. except:
  29. print('请先扫描登录或完成验证码识别')
  30. else:
  31. print('点击 重新上传')
  32. break
  33. finally:
  34. time.sleep(1)
  35. def 上传图片(文件路径):
  36. dialog = win32gui.FindWindow('#32770', u'打开') # 对话框
  37. ComboBoxEx32 = win32gui.FindWindowEx(dialog, 0, 'ComboBoxEx32', None)
  38. ComboBox = win32gui.FindWindowEx(ComboBoxEx32, 0, 'ComboBox', None)
  39. Edit = win32gui.FindWindowEx(ComboBox, 0, 'Edit', None) # 上面三句依次寻找对象,直到找到输入框Edit对象的句柄
  40. button = win32gui.FindWindowEx(dialog, 0, 'Button', None) # 打开按钮
  41. if Edit is not None and button is not None:
  42. time.sleep(0.5)
  43. win32gui.SendMessage(Edit, win32con.WM_SETTEXT, None, 文件路径) # 往输入框输入绝对地址
  44. print('上传:', 文件路径)
  45. time.sleep(0.5)
  46. win32gui.SendMessage(dialog, win32con.WM_COMMAND, 1, button) # 点 打开 按钮
  47. time.sleep(5)
  48. def 点击下载():
  49. while True:
  50. try:
  51. download = browser.find_element(By.CSS_SELECTOR, '.border_wrap.download_wrap')
  52. download.click()
  53. time.sleep(0.5)
  54. confirm = browser.find_element(By.CSS_SELECTOR, '.dialog-content>.content_wrap>.download_wrap')
  55. confirm.click()
  56. except:
  57. print('请先扫描登录或完成验证码识别')
  58. else:
  59. print('点击 下载')
  60. break
  61. finally:
  62. time.sleep(1)
  63. 文件夹路径 = r'E:\前任女友'
  64. names = os.listdir(文件夹路径) # 列举出该目录下所有的文件名
  65. for name in names:
  66. path = os.path.join(文件夹路径, name) # 拼接出图片完整路径
  67. 点击重新上传()
  68. 上传图片(path)
  69. 点击下载()
  70. print('恭喜!全部完成')

在完整代码中加入了异常处理,如果遇到需要扫码登录或者验证码,手动操作一下,还会继续执行下去的。以上就是全部内容,希望对大家有所帮助,谢谢欣赏观看,

相关推荐
阅读 +