Python中qrcode二维码模块的详细使用教程

安利一波我开的专栏: https://segmentfault.com/blog/cheez_pythonhttps://zhuanlan.zhihu.com/cheezpython

https://github.com/lincolnloop/python-qrcode

声明

import qrcode

使用

QRCode 方法

qrcode.QRCode(
    version=1,
    error_correction=qrcode.ERROR_CORRECT_L,
    box_size=10,
    border=4,
    image_factory=None,
    mask_pattern=None
)
参数解释:
  1. version:控制二维码的大小,取值范围从 1 到 40。取最小值 1 时,二维码大小为 21*21。取值为 None (默认)或者使用fit=true参数(默认)时,二维码会自动调整大小。
  2. error_correction:控制二维码纠错级别。
    1. ERROR_CORRECT_L:大约 7%或者更少的错误会被更正。
    2. ERROR_CORRECT_M:默认值,大约 15%或者更少的错误会被更正。
    3. ERROR_CORRECT_Q:大约 25%或者更少的错误会被更正。
    4. ERROR_CORRECT_H:大约 30%或者更少的错误会被更正。
  3. box_size:控制二维码中每个格子的像素数,默认为 10。
  4. border:控制二维码四周留白包含的格子数,默认为 4。
  5. image_factory:选择生成图片的形式,默认为 PIL 图像。
  6. mask_pattern:选择生成图片的的掩模。
方法属性解释:

常用方法:

  1. add_data(str,optimize=20):添加要转换的文字到data参数;如果使用了optimize优化参数,数据将被拆分为多个块来进行优化,以找到一个长度至少为这个值的足够简洁的方式来生成二维码。设置为“ 0 ”以避免优化。
  2. make(fit=True):当fit参数为真或者没有给出version参数时,将会调用best_fit方法来找到适合数据的最小尺寸。如果没有设置mask_pattern,将会调用best_mask_pattern方法来找到找到最有效的掩模图案。最后将这些数据传递给makeImpl方法来生成二维码。qrcode本体的make方法不一样的是,这个方法没有任何返回值。
  3. make_image(fill_color=None, back_color=None,image_factory=None):创建二维码的图像并返回,默认为 PIL 图像。** 如果要让二维码有颜色,可以在这里设置。**
  4. clear:清空数据
  5. get_matrix:返回二维码数组。
  6. print_ascii(out=None, tty=False, invert=False):这个方法就比较有趣了,可以用字符画的形式来输出二维码,但是扫的时候一般都扫不出来。image其中的invert参数是决定是否反转颜色的参数,默认为假,如果为真的话会这样:image

其他方法:

  1. best_fit(start=self.version):找到适合数据所需的最小尺寸。
  2. best_mask_pattern():找到最有效的掩模图案。
  3. makeImpl(test, mask_pattern):生成二维码的直接函数
  4. map_data:(内部函数,无需了解)
  5. print_tty(out=None):用 TTY 颜色输出二维码,如果没有给出out参数,会使用sys.stdout
  6. setup_position_adjust_pattern:(内部函数,无需了解)
  7. setup_position_probe_pattern:(内部函数,无需了解)
  8. setup_timing_pattern:(内部函数,无需了解)
  9. setup_type_info:(内部函数,无需了解)
  10. setup_type_number:(内部函数,无需了解)

属性(这些大家基本都不用管):

  1. border:
  2. box_size:
  3. data_cache:
  4. data_list:
  5. error_correction:
  6. image_factory:
  7. mask_pattern:
  8. modules:
  9. modules_count:
  10. version:

生成 SVG 图像

qrcode可以生成三种不同的 svg 图像,一种是用路径表示的 svg,一种是用矩形集合表示的完整 svg 文件,还有一种是用矩形集合表示的 svg 片段。第一种用路径表示的 svg 其实就是矢量图,可以在图像放大的时候可以保持图片质量,而另外两种可能会在格子之间出现空隙。

这三种分别对应了 svg.py 中的 SvgPathImage、SvgImage 和 SvgFragmentImage 类。在调用qrcode.make函数或者实例化QRCode时当作image_factory参数的值传入就可以了。

import qrcode.image.svg

if method == ‘basic’: # Simple factory, just a set of rects. factory = qrcode.image.svg.SvgImage elif method == ‘fragment’: # Fragment factory (also just a set of rects) factory = qrcode.image.svg.SvgFragmentImage else: # Combined path factory, fixes white space that may occur when zooming factory = qrcode.image.svg.SvgPathImage

img = qrcode.make(‘Some data here’, image_factory=factory)

生成 PNG 图像

执行命令安装pymaging相关模块:

pip install git+git://github.com/ojii/pymaging.git#egg=pymaging

pip install git+git://github.com/ojii/pymaging-png.git#egg=pymaging-png

然后给image_factor参数传入qrcode.image.pure.PymagingImage就可以生成 PNG 图片了。

import qrcode
from qrcode.image.pure import PymagingImage
img = qrcode.make('Some data here', image_factory=PymagingImage)

这是作者推荐的方式,但是我个人认为,完全没有必要这么麻烦,直接用默认的 PIL 就可以获取 PNG 图片了,例子看下文。

make 方法

make方法实际上就是在内部调用了QRCode(要转换的文本).make_image(),最后(默认)返回了一个 PIL 图像对象。

# 显示图片
qrcode.make("hello world!").show()
# 保存 PNG 图片
qrcode.make("hello world!").save('hello.png')

run_example 方法

生成一个作者项目网站地址的二维码并显示出来。

翻译自作者的Github 地址中的 README 和具体代码注释。


Python中qrcode二维码模块的详细使用教程

8 回复

挽尊


嘿,这个问题问得好,qrcode这个库确实好用。我来给你写个详细的例子,从安装到生成带Logo的二维码,代码都能直接跑。

1. 安装和基础使用

import qrcode

# 最简单的二维码
img = qrcode.make('https://www.example.com')
img.save('basic_qr.png')
print("基础二维码已生成:basic_qr.png")

2. 高级配置和自定义

import qrcode
from qrcode.constants import ERROR_CORRECT_H

# 创建QRCode对象进行详细配置
qr = qrcode.QRCode(
    version=7,  # 控制二维码大小,1-40,数字越大尺寸越大
    error_correction=ERROR_CORRECT_H,  # 纠错级别:L(7%) M(15%) Q(25%) H(30%)
    box_size=10,  # 每个小格子的像素大小
    border=4,  # 边框的格子数
)

# 添加数据
qr.add_data('https://www.yourwebsite.com/product/12345')
qr.make(fit=True)

# 创建图像
img = qr.make_image(fill_color="black", back_color="white")

# 保存
img.save('custom_qr.png')
print("自定义二维码已生成:custom_qr.png")

3. 生成带Logo的二维码

import qrcode
from PIL import Image
import os

def create_qr_with_logo(data, logo_path, output_path):
    # 先生成基础二维码
    qr = qrcode.QRCode(
        version=5,
        error_correction=qrcode.constants.ERROR_CORRECT_H,
        box_size=10,
        border=2
    )
    qr.add_data(data)
    qr.make(fit=True)
    
    # 创建二维码图片
    qr_img = qr.make_image(fill_color="black", back_color="white").convert('RGB')
    
    # 打开Logo并调整大小
    logo = Image.open(logo_path)
    
    # 计算Logo大小(二维码大小的1/4)
    qr_width, qr_height = qr_img.size
    logo_size = qr_width // 4
    
    # 调整Logo尺寸并保持宽高比
    logo.thumbnail((logo_size, logo_size), Image.Resampling.LANCZOS)
    
    # 计算Logo位置(居中)
    logo_pos = ((qr_width - logo.size[0]) // 2, 
                (qr_height - logo.size[1]) // 2)
    
    # 将Logo粘贴到二维码上
    qr_img.paste(logo, logo_pos, logo if logo.mode == 'RGBA' else None)
    
    # 保存
    qr_img.save(output_path)
    print(f"带Logo的二维码已生成:{output_path}")

# 使用示例
if __name__ == "__main__":
    # 确保有logo文件,这里假设当前目录有logo.png
    if os.path.exists("logo.png"):
        create_qr_with_logo(
            data="https://www.yourcompany.com",
            logo_path="logo.png",
            output_path="qr_with_logo.png"
        )
    else:
        print("请先准备一个logo.png文件")

4. 生成彩色二维码

import qrcode
from PIL import Image

# 创建彩色二维码
qr = qrcode.QRCode(
    version=3,
    error_correction=qrcode.constants.ERROR_CORRECT_Q,
    box_size=15,
    border=2
)
qr.add_data('COLORFUL QR CODE EXAMPLE')
qr.make(fit=True)

# 使用渐变色
img = qr.make_image(fill_color=(40, 120, 200), back_color=(230, 240, 250))
img.save('colorful_qr.png')
print("彩色二维码已生成:colorful_qr.png")

5. 批量生成二维码

import qrcode
import os

def batch_generate_qrcodes(data_list, output_dir="qrcodes"):
    # 创建输出目录
    if not os.path.exists(output_dir):
        os.makedirs(output_dir)
    
    for i, data in enumerate(data_list, 1):
        # 生成二维码
        img = qrcode.make(data)
        
        # 保存文件
        filename = f"qr_{i:03d}.png"
        filepath = os.path.join(output_dir, filename)
        img.save(filepath)
        
        print(f"已生成:{filename} - 内容:{data[:30]}...")
    
    print(f"\n批量生成完成!共生成 {len(data_list)} 个二维码到 '{output_dir}' 目录")

# 使用示例
urls = [
    "https://example.com/page1",
    "https://example.com/page2",
    "https://example.com/page3",
    "https://example.com/page4",
    "https://example.com/page5"
]

batch_generate_qrcodes(urls)

6. 生成SVG格式的二维码

import qrcode
import qrcode.image.svg

# 方法1:使用内置的SVG工厂
factory = qrcode.image.svg.SvgPathImage
svg_img = qrcode.make('SVG QR Code Example', image_factory=factory)
svg_img.save('qr_svg.svg')
print("SVG二维码已生成:qr_svg.svg")

# 方法2:生成更简单的SVG
simple_factory = qrcode.image.svg.SvgImage
svg_img_simple = qrcode.make('Simple SVG QR', image_factory=simple_factory)
svg_img_simple.save('qr_simple.svg')

核心参数说明:

  • version:1-40,控制二维码容量,会自动调整
  • error_correction:纠错级别,H级最耐损但数据容量最小
  • box_size:每个格子的像素,影响最终图片大小
  • border:边框宽度,至少是4

一句话建议: 根据需求选择合适的纠错级别和版本,带Logo时记得用H级纠错。

声明,兄弟啊…

怎么了

怎么生成一个好看的 QR 码?

这个我一般都是用微信小程序之类的,自己生成的最多就是彩色,然后再加个 logo😂

挽尊

回到顶部