再也不用担心图片水印了,自制python去水印代码分享
ztj100 2024-11-11 15:15 11 浏览 0 评论
起因
我找了个免费生成图标的网站,但下载是需要掏钱了,直接屏幕截图有水印,这难得倒技术宅吗?我在人工智能的帮助下写了个去水印的Python程序。
程序
import os
import cv2
import numpy as np
def remove_watermark(image, gray_color, white_color, tolerance=10):
# 确保图像是 BGR 格式
if len(image.shape) == 2:
image = cv2.cvtColor(image, cv2.COLOR_GRAY2BGR)
elif image.shape[2] == 4:
image = cv2.cvtColor(image, cv2.COLOR_BGRA2BGR)
# 创建灰色和白色的掩码
lower_gray = np.array([max(0, c - tolerance) for c in gray_color])
upper_gray = np.array([min(255, c + tolerance) for c in gray_color])
lower_white = np.array([max(0, c - tolerance) for c in white_color])
upper_white = np.array([min(255, c + tolerance) for c in white_color])
mask_gray = cv2.inRange(image, lower_gray, upper_gray)
mask_white = cv2.inRange(image, lower_white, upper_white)
# 合并灰色和白色掩码
mask_combined = cv2.bitwise_or(mask_gray, mask_white)
# 反转掩码以获取非灰色和非白色区域
mask_content = cv2.bitwise_not(mask_combined)
# 创建白色背景
white_bg = np.ones_like(image) * 255
# 将内容放到白色背景上
result = cv2.bitwise_and(image, image, mask=mask_content)
result = cv2.add(result, cv2.bitwise_and(white_bg, white_bg, mask=cv2.bitwise_not(mask_content)))
return result
# 设置水印颜色(BGR 格式)
gray_color = (239, 239, 239) # 灰色水印
white_color = (255, 255, 255) # 白色背景
# 获取当前文件夹中的所有PNG图片文件
image_files = [f for f in os.listdir('.') if f.lower().endswith('.png')]
for image_file in image_files:
try:
print(f"正在处理: {image_file}")
# 读取图像
image = cv2.imread(image_file, cv2.IMREAD_UNCHANGED)
if image is None:
print(f"无法读取图像: {image_file}")
continue
print(f"成功读取图像,形状: {image.shape}, 数据类型: {image.dtype}")
# 去除水印
result = remove_watermark(image, gray_color, white_color)
# 生成新的文件名
new_filename = f"{os.path.splitext(image_file)[0]}_no_watermark.png"
# 保存新图像
cv2.imwrite(new_filename, result)
print(f"处理完成: {new_filename}")
except Exception as e:
print(f"处理 {image_file} 时出错: {str(e)}")
import traceback
traceback.print_exc()
print("所有图像处理完毕")
用法
得把要去水印的图片名字整得简单一些,然后和python脚本放在同一个文件夹,然后运行脚本就行啦。
代码的解释
这个脚本的主要目的是从图像中移除水印,特别是针对白底图像上的灰色水印。以下是代码的主要部分及其功能:
1. `remove_watermark` 函数:
- 确保输入图像是 BGR 格式。
- 创建灰色(水印)和白色(背景)的颜色范围掩码。
- 合并这两个掩码,然后反转,得到图像中非水印和非背景的部分。
- 创建一个纯白色背景。
- 将图像的主要内容(非水印和非背景部分)提取出来,放到白色背景上。
2. 主程序:
- 定义水印颜色(灰色)和背景颜色(白色)。
- 获取当前文件夹中所有的 PNG 图片文件。
- 对每个图片文件进行处理:
* 读取图像。
* 调用 `remove_watermark` 函数去除水印。
* 生成新的文件名(添加 "_no_watermark" 后缀)。
* 保存处理后的图像。
3. 错误处理:
- 使用 try-except 块来捕获和处理可能出现的错误。
- 如果无法读取图像或处理过程中出现错误,会打印相应的错误信息。
这个脚本的核心思想是通过颜色识别来分离图像的主要内容和水印/背景,然后只保留主要内容,并将其放置在新的白色背景上。这种方法特别适用于有简单背景(如白色)和单一颜色水印的图像。
脚本的优点是它能批量处理文件夹中的所有 PNG 图像,并且使用了 OpenCV 库来进行高效的图像处理。然而,它可能不适用于有复杂背景或水印的图像,在这些情况下可能需要更高级的图像处理技术。
相关推荐
- Vue 技术栈(全家桶)(vue technology)
-
Vue技术栈(全家桶)尚硅谷前端研究院第1章:Vue核心Vue简介官网英文官网:https://vuejs.org/中文官网:https://cn.vuejs.org/...
- vue 基础- nextTick 的使用场景(vue的nexttick这个方法有什么用)
-
前言《vue基础》系列是再次回炉vue记的笔记,除了官网那部分知识点外,还会加入自己的一些理解。(里面会有部分和官网相同的文案,有经验的同学择感兴趣的阅读)在开发时,是不是遇到过这样的场景,响应...
- vue3 组件初始化流程(vue组件初始化顺序)
-
学习完成响应式系统后,咋们来看看vue3组件的初始化流程既然是看vue组件的初始化流程,咋们先来创建基本的代码,跑跑流程(在app.vue中写入以下内容,来跑流程)...
- vue3优雅的设置element-plus的table自动滚动到底部
-
场景我是需要在table最后添加一行数据,然后把滚动条滚动到最后。查网上的解决方案都是读取html结构,暴力的去获取,虽能解决问题,但是不喜欢这种打补丁的解决方案,我想着官方应该有相关的定义,于是就去...
- Vue3为什么推荐使用ref而不是reactive
-
为什么推荐使用ref而不是reactivereactive本身具有很大局限性导致使用过程需要额外注意,如果忽视这些问题将对开发造成不小的麻烦;ref更像是vue2时代optionapi的data的替...
- 9、echarts 在 vue 中怎么引用?(必会)
-
首先我们初始化一个vue项目,执行vueinitwebpackechart,接着我们进入初始化的项目下。安装echarts,npminstallecharts-S//或...
- 无所不能,将 Vue 渲染到嵌入式液晶屏
-
该文章转载自公众号@前端时刻,https://mp.weixin.qq.com/s/WDHW36zhfNFVFVv4jO2vrA前言...
- vue-element-admin 增删改查(五)(vue-element-admin怎么用)
-
此篇幅比较长,涉及到的小知识点也比较多,一定要耐心看完,记住学东西没有耐心可不行!!!一、添加和修改注:添加和编辑用到了同一个组件,也就是此篇文章你能学会如何封装组件及引用组件;第二能学会async和...
- 最全的 Vue 面试题+详解答案(vue面试题知识点大全)
-
前言本文整理了...
- 基于 vue3.0 桌面端朋友圈/登录验证+60s倒计时
-
今天给大家分享的是Vue3聊天实例中的朋友圈的实现及登录验证和倒计时操作。先上效果图这个是最新开发的vue3.x网页端聊天项目中的朋友圈模块。用到了ElementPlus...
- 不来看看这些 VUE 的生命周期钩子函数?| 原力计划
-
作者|huangfuyk责编|王晓曼出品|CSDN博客VUE的生命周期钩子函数:就是指在一个组件从创建到销毁的过程自动执行的函数,包含组件的变化。可以分为:创建、挂载、更新、销毁四个模块...
- Vue3.5正式上线,父传子props用法更丝滑简洁
-
前言Vue3.5在2024-09-03正式上线,目前在Vue官网显最新版本已经是Vue3.5,其中主要包含了几个小改动,我留意到日常最常用的改动就是props了,肯定是用Vue3的人必用的,所以针对性...
- Vue 3 生命周期完整指南(vue生命周期及使用)
-
Vue2和Vue3中的生命周期钩子的工作方式非常相似,我们仍然可以访问相同的钩子,也希望将它们能用于相同的场景。...
- 救命!这 10 个 Vue3 技巧藏太深了!性能翻倍 + 摸鱼神器全揭秘
-
前端打工人集合!是不是经常遇到这些崩溃瞬间:Vue3项目越写越卡,组件通信像走迷宫,复杂逻辑写得脑壳疼?别慌!作为在一线摸爬滚打多年的老前端,今天直接甩出10个超实用的Vue3实战技巧,手把...
- 怎么在 vue 中使用 form 清除校验状态?
-
在Vue中使用表单验证时,经常需要清除表单的校验状态。下面我将介绍一些方法来清除表单的校验状态。1.使用this.$refs...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- Vue 技术栈(全家桶)(vue technology)
- vue 基础- nextTick 的使用场景(vue的nexttick这个方法有什么用)
- vue3 组件初始化流程(vue组件初始化顺序)
- vue3优雅的设置element-plus的table自动滚动到底部
- Vue3为什么推荐使用ref而不是reactive
- 9、echarts 在 vue 中怎么引用?(必会)
- 无所不能,将 Vue 渲染到嵌入式液晶屏
- vue-element-admin 增删改查(五)(vue-element-admin怎么用)
- 最全的 Vue 面试题+详解答案(vue面试题知识点大全)
- 基于 vue3.0 桌面端朋友圈/登录验证+60s倒计时
- 标签列表
-
- idea eval reset (50)
- vue dispatch (70)
- update canceled (42)
- order by asc (53)
- spring gateway (67)
- 简单代码编程 贪吃蛇 (40)
- transforms.resize (33)
- redisson trylock (35)
- 卸载node (35)
- np.reshape (33)
- torch.arange (34)
- node卸载 (33)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- exceptionininitializererror (33)
- vue foreach (34)
- idea设置编码为utf8 (35)
- vue 数组添加元素 (34)
- std find (34)
- tablefield注解用途 (35)
- python str转json (34)
- java websocket客户端 (34)
- tensor.view (34)
- java jackson (34)