百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

再也不用担心图片水印了,自制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...

取消回复欢迎 发表评论: