比较两个图片是否完全相同的python实现

要比较两个图片是否完全相同,可以通过以下几个步骤来规划思路:

  1. 获取图片数据:首先需要将两张图片加载并获取它们的像素数据。可以使用Python中的OpenCV或PIL库等来加载和处理图片数据。

  2. 比较图片尺寸:在比较两张图片是否完全相同之前,可以先比较它们的尺寸是否相同。如果尺寸不同,则可以直接判定两张图片不同。

  3. 逐像素比较:遍历每个像素点并逐点比较它们的RGB值(或灰度值)。如果两张图片的对应像素点的RGB值完全相同,则说明对应位置的像素完全相同。

  4. 计算哈希值比较:通过计算图片的哈希值(如局部敏感哈希算法(pHash)、均值哈希(aHash)等),然后比较哈希值是否相等,来判断两张图片是否相同。

  5. 使用结构相似性比较:结构相似性比较指标(Structural Similarity Index,SSIM)可用于比较两个图片的相似性。可以计算两张图片之间的SSIM指标,并设定一个阈值判断图片差异是否在可接受范围内。

  6. 比较直方图:计算两张图片的直方图,并比较它们之间的差异。可以使用直方图距离度量来判断两张图片的相似度。

  7. 使用开源工具:除了以上方法,也可以考虑使用一些开源的图像处理工具或库,如ImageMagick、OpenCV等,它们提供了丰富的图像处理功能,包括比较图片的相似性。

测app的时候总会需要比较两个图片是否一致,以下是python实现。

import cv2
import numpy as np
import subprocess
import os

class BaseImage(object):
    '''
    操作图片
    '''
    def __init__(self, driver):
        self.driver = driver

    # 去掉顶部栏
    def remove_top_bar(self,image):
        height, width = image.shape[:2]
        top_bar_height = 250 # mumu 顶部栏250
        image = image[top_bar_height:height, 0:width]
        return image

    def image_equivalence(self,png1,png2):
        '''比较两个截图是否完全相等'''
        image_start = cv2.imread(png1)
        image_start_cropped = self.remove_top_bar(image_start)
        image_current = cv2.imread(png2)
        image_current_cropped = self.remove_top_bar(image_current)
        # 保存裁剪后的图片
        # cv2.imwrite(png1, image_start_cropped)
        # cv2.imwrite(png2, image_current_cropped)
        # 判断两张裁剪后的图片是否完全一致
        if image_start_cropped.shape == image_current_cropped.shape and not (np.bitwise_xor(image_start_cropped, image_current_cropped).any()):
            print("两张图片完全一致!")
            subprocess.call(["adb", "shell", "rm", "/sdcard/" + png1])# 删除临时生成的截图文件
            subprocess.call(["adb", "shell", "rm", "/sdcard/" + png2])
            os.remove(png1)
            os.remove(png2)
            return True
        else:
            print("两张图片不完全一致!")
            subprocess.call(["adb", "shell", "rm", "/sdcard/" + png1])# 删除临时生成的截图文件
            subprocess.call(["adb", "shell", "rm", "/sdcard/" + png2])
            return False

Python中,可以使用图像处理库如PIL(Python Imaging Library)或更先进的像OpenCV、NumPy等来比较两张图片是否相似。常用的一种方法是比较它们的像素值,如果差异在一定阈值内,就可以认为是相同的。这里简单概述一种常见的基于像素直方图对比的方式: 1. **读取图片**:首先使用PIL的`Image.open()`函数加载两张图片。 ```python from PIL import Image img1 = Image.open('image1.jpg') img2 = Image.open('image2.jpg') ``` 2. **预处理**:将图片转换为灰度图像,因为颜色信息可能会引入更多复杂性。也可以选择其他特征如纹理、形状等,取决于具体需求。 ```python img1_gray = img1.convert('L') img2_gray = img2.convert('L') ``` 3. **提取像素值**:获取每张图片的像素值数组。 ```python pixels1 = list(img1_gray.getdata()) pixels2 = list(img2_gray.getdata()) ``` 4. **计算直方图**:对像素值进行统计,得到每个灰度级的像素计数。 5. **比较直方图**:可以计算两幅图像像素值的欧几里得距离、余弦相似度等来评估它们的相似度。例如,使用欧氏距离: ```python import numpy as np histogram_diff = np.linalg.norm(np.array(pixels1) - np.array(pixels2)) ``` 6. **设定阈值**:如果直方图差异小于某个预设的阈值,通常认为两张图片很相似。 ```python threshold = 100 # 这是一个示例值,实际应用中可能需要调整 if histogram_diff < threshold: print("两张图片相似") else: print("两张图片不相似") ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

balahalalala

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值