【python】OpenCV—QR Code

在这里插入图片描述

1 QR Code

QR Code(Quick Response Code)是一种二维条码,由日本Denso-Wave公司于1994年发明。QR Code的主要特点是存储信息量大、编码范围广、容错能力强、识读速度快,并且支持全方位识读。这种条码最初是为了在汽车制造行业快速追踪零部件而设计的,但现在已经广泛应用于各种领域,如移动支付、产品防伪、广告宣传、物流追踪等。

QR Code的构成:

  • 定位图案:位于二维码的左上角、右上角和左下角,用于确定二维码的角度和位置。
  • 校正图案:在二维码中有多个校正图案,用于在二维码发生形变时帮助解码器校正。
  • 格式信息:包含有关错误检测和校正的信息,以及使用的掩码版本。
  • 版本信息:表明QR Code的版本号,版本号越高,可以存储的信息越多,但QR Code的尺寸也越大。
  • 数据和纠错码:存储实际的信息和用于错误检测和校正的冗余数据。

QR Code的使用:

  • 移动支付:通过手机扫描QR Code进行快速支付。
  • 社交媒体:扫描QR Code可以直接跳转到某个社交媒体页面或添加好友。
  • 产品防伪:在产品包装上打印QR Code,消费者可以扫描验证产品的真伪。
  • 广告宣传:在广告中打印QR Code,观众可以通过扫描直接访问相关网站或获取更多信息。
  • 物流追踪:在物流包裹上打印QR Code,可以方便地进行物流追踪和查询。

QR Code的生成和扫描通常需要使用专门的软件或应用,这些软件和应用可以在各种平台上找到,如手机、电脑等。

2 准备工作

OpenCV基础(22)使用OpenCV生成及读取二维码以及与Zbar比较

pip install qrcode
pip install  pillow
pip install  pyzbar
pip install zbar

3 生成 QR 码

generateQRCode.py

#!/usr/bin/python3
# -*- encoding: utf-8 -*-
"""
@File    : generateQRCode.py
@Time    : 2021/10/12 14:13
@Author  : David
@Software: PyCharm
"""

# 生成二维码
import qrcode

# 二维码包含的示例数据
data = "https://blog.csdn.net/bryant_meng"
# 生成的二维码图片名称
filename = "CSDNBlog.png"
# 生成二维码
img = qrcode.make(data)
# 保存成图片输出
img.save(filename)

生成本博客主页的二维码

在这里插入图片描述

4 QR 码加 logo

# 导入图像处理库PIL的image方法
from PIL import Image
# qrcode是第三方库,需要pip install qrcode安装
import qrcode

# 初步生成二维码图像
qr = qrcode.QRCode(version=None, error_correction=qrcode.constants.ERROR_CORRECT_H, box_size=8, border=4)
# 添加二维码信息,可以是文字、数字、url
qr.add_data("https://blog.csdn.net/bryant_meng")
# 生成二维码实例
qr.make(fit=True)

# 把实例转换成图片
img = qr.make_image()
# 把颜色模式转换为RGBA
img = img.convert("RGBA")

# 打开logo文件,二维码中心logo图片
icon = Image.open("2.jpg")

# 先得出二维码的宽和高
img_w, img_h = img.size
factor = 3
# 通过二维码宽高计算出logo图片宽和高的最大限度
size_w = int(img_w / factor)
size_h = int(img_h / factor)

# 获取logo的宽和高
icon_w, icon_h = icon.size
# 比较logo宽高和最大限度宽高,如果超过最大限度就将logo尺寸调整到最大限度
if icon_w > size_w:
    icon_w = size_w
if icon_h > size_h:
    icon_h = size_h
# 重新调整logo的尺寸  Image.NEAREST :低质量 Image.BILINEAR:双线性
# Image.BICUBIC :三次样条插值 Image.ANTIALIAS:高质量
icon = icon.resize((icon_w, icon_h), Image.ANTIALIAS)

# 根据logo和图片的长宽确定logo的位置
w = int((img_w - icon_w) / 2)
h = int((img_h - icon_h) / 2)
# 将logo颜色模式转换为RGBA
icon = icon.convert("RGBA")
# 将logo图片粘贴到二维码的指定位置
img.paste(icon, (w, h))

# 保存二维码到指定位置,设置二维码格式
img.save('CSDNWithLOGO.png')

输入
在这里插入图片描述
输出

在这里插入图片描述

5 读取 QR 码

qrCodeOpencv.py

import cv2
import numpy as np
import sys
import time

if len(sys.argv) > 1:
    inputImage = cv2.imread(sys.argv[1])
else:
    inputImage = cv2.imread("CSDNBlog.png")
    # inputImage = cv2.imread("qrcode-learnopencv.jpg")


# Display barcode and QR code location
def display(im, bbox):
    cv2.line(im, tuple(bbox[0]), tuple(bbox[1]), (255, 0, 0), 5)
    cv2.line(im, tuple(bbox[1]), tuple(bbox[2]), (255, 0, 0), 5)
    cv2.line(im, tuple(bbox[2]), tuple(bbox[3]), (255, 0, 0), 5)
    cv2.line(im, tuple(bbox[3]), tuple(bbox[0]), (255, 0, 0), 5)

    # Write results
    cv2.imwrite("Results.jpg", im)

    # Display results
    cv2.imshow("Results", im)


# Create a qrCodeDetector Object
qrDecoder = cv2.QRCodeDetector()

# Detect and decode the qrcode
t = time.time()
data, bbox, rectifiedImage = qrDecoder.detectAndDecode(inputImage)
print("Time Taken for Detect and Decode : {:.3f} seconds".format(time.time() - t))
if len(data) > 0:
    print("Decoded Data : {}".format(data))
    display(inputImage, np.array(bbox[0], dtype=np.int32))
    rectifiedImage = np.uint8(rectifiedImage)
    cv2.imwrite("Rectified_QRCode.jpg", rectifiedImage)
    cv2.imshow("Rectified QRCode", rectifiedImage)
else:
    print("QR Code not detected")
    cv2.imshow("Results", inputImage)
cv2.imwrite("output.jpg", inputImage)
cv2.waitKey(0)
cv2.destroyAllWindows()

生成 Results.jpg

在这里插入图片描述

Recitified_QRCode.jpg

在这里插入图片描述

6 与 Zbar 比较

import cv2
import numpy as np
import sys
import time
import pyzbar.pyzbar as pyzbar

cap = cv2.VideoCapture("qr-code_animated.gif")
hasFrame, frame = cap.read()
vid_writer = cv2.VideoWriter('output.avi', cv2.VideoWriter_fourcc('M', 'J', 'P', 'G'), 10,
                             (frame.shape[1], frame.shape[0]))


# Display barcode and QR code location
def display(im, decodedObjects):
    # Loop over all decoded objects
    for decodedObject in decodedObjects:
        points = decodedObject.polygon

        # If the points do not form a quad, find convex hull
        if len(points) > 4:
            hull = cv2.convexHull(np.array([point for point in points], dtype=np.float32))
            hull = list(map(tuple, np.squeeze(hull)))
        else:
            hull = points;

        # Number of points in the convex hull
        n = len(hull)

        # Draw the convext hull
        for j in range(0, n):
            cv2.line(im, hull[j], hull[(j + 1) % n], (255, 0, 0), 3)

    # Display results
    # cv2.imshow("Results", im);


# Create a qrCodeDetector Object
qrDecoder = cv2.QRCodeDetector()

# Detect and decode the qrcode
t = time.time()
while (1):
    hasFrame, inputImage = cap.read()
    if not hasFrame:
        break
    decodedObjects = pyzbar.decode(inputImage)
    if len(decodedObjects):
        zbarData = decodedObjects[0].data
    else:
        zbarData = ''
    opencvData, bbox, rectifiedImage = qrDecoder.detectAndDecode(inputImage)
    if zbarData:
        cv2.putText(inputImage, "ZBAR : {}".format(zbarData.decode()), (10, 50), cv2.FONT_HERSHEY_SIMPLEX, 1,
                    (0, 255, 0), 2, cv2.LINE_AA)
    else:
        cv2.putText(inputImage, "ZBAR : QR Code NOT Detected", (10, 50), cv2.FONT_HERSHEY_SIMPLEX, 1, (0, 0, 255), 2,
                    cv2.LINE_AA)
    if opencvData:
        cv2.putText(inputImage, "OpenCV:{}".format(opencvData), (10, 150), cv2.FONT_HERSHEY_SIMPLEX, 1, (0, 255, 0), 2,
                    cv2.LINE_AA)
    else:
        cv2.putText(inputImage, "OpenCV:QR Code NOT Detected", (10, 150), cv2.FONT_HERSHEY_SIMPLEX, 1, (0, 0, 255), 2,
                    cv2.LINE_AA)

    display(inputImage, decodedObjects)
    cv2.imshow("Result", inputImage)
    vid_writer.write(inputImage)
    k = cv2.waitKey(20)
    if k == 27:
        break
cv2.destroyAllWindows()
vid_writer.release()

输入

在这里插入图片描述

输出为视频,我们转化成 gif

在这里插入图片描述
可以看出 qrcode 库没有 pyzbar 库检测结果稳定

  • 29
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: PythonOpenCV库是一个广泛使用的计算机视觉和图像处理库,可以用于许多图像处理任务,包括二维码的识别。 要使用PythonOpenCV库进行二维码的识别,你需要安装OpenCV库和一个能够解码二维码的额外库,比如`pyzbar`。 首先,你需要在你的Python环境中安装OpenCV库和`pyzbar`库。你可以使用`pip`命令运行以下命令进行安装: ``` pip install opencv-python pip install pyzbar ``` 安装完成后,你可以使用以下代码来识别二维码: ```python import cv2 from pyzbar import pyzbar def decode_qr_code(image): # 读取图像 gray = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY) # 转换为灰度图像 # 解码二维码 barcodes = pyzbar.decode(gray) # 处理解码结果 for barcode in barcodes: # 提取二维码的边界框坐标 (x, y, w, h) = barcode.rect # 绘制二维码的边界框 cv2.rectangle(image, (x, y), (x + w, y + h), (0, 255, 0), 2) # 提取二维码的数据 barcode_data = barcode.data.decode("utf-8") # 在图像上显示二维码的数据 cv2.putText(image, barcode_data, (x, y - 10), cv2.FONT_HERSHEY_SIMPLEX, 0.5, (0, 255, 0), 2) # 返回带有二维码信息的图像 return image # 读取图像文件 image = cv2.imread("qr_code.jpg") # 调用函数进行二维码识别 result = decode_qr_code(image) # 显示识别结果 cv2.imshow("QR Code Detection", result) cv2.waitKey(0) ``` 上述代码中,`decode_qr_code()`函数接受一个图像作为输入,将它转换为灰度图像,然后使用`pyzbar`库解码图像中的二维码。解码结果包含二维码的边界框坐标和数据。然后,它在原始图像上绘制出二维码的边界框,并将二维码的数据在图像上显示出来。 以上就是使用PythonOpenCV库识别二维码的简单示例。你可以将以上代码与你的应用程序结合,以满足你的具体需求。 ### 回答2: Python中的OpenCV库可以用于识别二维码。为了实现这个功能,我们需要安装PythonOpenCV库和一个用于二维码识别的额外库。 首先,我们需要使用pip安装OpenCV库。在终端中运行以下命令: ``` pip install opencv-python ``` 接下来,我们需要下载一个用于二维码识别的库,比如ZBar库。在终端中运行以下命令: ``` pip install pyzbar ``` 一旦我们安装了这些库,我们可以使用以下代码在Python中识别二维码: ```python import cv2 from pyzbar.pyzbar import decode def read_qr_code(image_path): # 读取图像 image = cv2.imread(image_path) # 将图像转换为灰度图 gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY) # 解码二维码 qr_codes = decode(gray_image) # 打印结果 for qr_code in qr_codes: data = qr_code.data.decode('utf-8') print("二维码内容:", data) # 使用例子 image_path = 'path_to_image.jpg' read_qr_code(image_path) ``` 在此代码中,我们首先使用`cv2.imread()`函数读取图像,然后将其转换为灰度图像。接下来,我们使用`decode`函数解码图像中的二维码。最后,我们可以使用`.data`属性获取二维码的内容,并使用`decode('utf-8')`将其转换为字符串。 注意:在使用此代码之前,请确保您已经安装了OpenCVpyzbar,并将`image_path`替换为您要识别二维码的图像的路径。 通过上述步骤,我们可以使用PythonOpenCV库和pyzbar库来识别图像中的二维码。 ### 回答3: Python OpenCV可以用来识别和解码二维码。可以使用Pyzbar库,该库提供了一个简单而高效的接口来解码二维码。 首先,确保已经在Python环境中安装了OpenCVPyzbar库。可以使用pip进行安装,命令如下: ``` pip install opencv-python pip install pyzbar ``` 接下来,需要加载并读取图像。可以使用OpenCV的`imread`函数来加载图像,然后使用`cv2.cvtColor`函数将其转换为灰度图像。然后,可以使用Pyzbar库的`decode`函数来解码二维码。代码示例如下: ```python import cv2 from pyzbar.pyzbar import decode # 加载并读取图像 image = cv2.imread("qr_code.png") # 将图像转换为灰度图像 gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY) # 解码二维码 decoded_objects = decode(gray_image) # 打印解码结果 for obj in decoded_objects: print("二维码数据:", obj.data) ``` 在上述代码中,`qr_code.png`是包含二维码的图像文件名。`decode`函数会返回一个包含解码结果的列表,每个元素都包含了解码后的二维码数据。我们可以遍历该列表并打印解码结果。 请确保图像中的二维码清晰可见,并且可以正确识别和解码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值