您的位置:首页 > 编程语言 > Python开发

Python使用QRCode模块生成二维码

2015-09-25 15:03 706 查看
简介

python-qrcode是个用来生成二维码图片的第三方模块,依赖于 PIL 模块和 qrcode 库。

简单用法
import qrcode
img = qrcode.make('hello, qrcode')
img.save('test.png')


高级用法

import qrcode
qr = qrcode.QRCode(
version=1,
error_correction=qrcode.constants.ERROR_CORRECT_L,
box_size=10,
border=4,
)
qr.add_data('hello, qrcode')
qr.make(fit=True)
img = qr.make_image()
img.save('123.png')


参数含义:

version:值为1~40的整数,控制二维码的大小(最小值是1,是个12×12的矩阵)。 如果想让程序自动确定,将值设置为 None 并使用 fit 参数即可。


error_correction:控制二维码的错误纠正功能。可取值下列4个常量。

  ERROR_CORRECT_L:大约7%或更少的错误能被纠正。

  ERROR_CORRECT_M(默认):大约15%或更少的错误能被纠正。

  ROR_CORRECT_H:大约30%或更少的错误能被纠正。

box_size:控制二维码中每个小格子包含的像素数。

border:控制边框(二维码与图片边界的距离)包含的格子数(默认为4,是相关标准规定的最小值)

python生成二维码,常用的模块有pyqrencode和qrcode。

一、用pyqrencode模块生成二维码

安装pyqrencode模块很复杂,依赖的东西也比较多,经过测试总结以下安装过程:

1、下载Cython:https://pypi.python.org/packages/source/C/Cython/Cython-0.19.1.tar.gz

安装:tar -zxf Cython-0.19.1.tar.gz && cd Cython-0.19.1 && python setup.py install

2、下载qrencode:http://fukuchi.org/works/qrencode/qrencode-3.4.2.tar.gz

安装前确认安装了yum install libpng-devel -y

安装:tar -zxf qrencode-3.4.2.tar.gz && cd qrencode-3.4.2 && ./configure && make && make install

3、下载Imaging:http://effbot.org/media/downloads/Imaging-1.1.7.tar.gz

安装:tar -zxf Imaging-1.1.7.tar.gz && cd Imaging-1.1.7 && python setup.py install

4、下载:https://codeload.github.com/bitly/pyqrencode/zip/master

安装:

unzip -q pyqrencode-master.zip

cd pyqrencode-master

easy_install cython

cython qrencode.pyx

python setup.py install

echo "/usr/local/lib">>/etc/ld.so.conf

ldconfig

5、用pyqrencode生成二维码

>>> from qrencode import Encoder

>>> encoder = Encoder()

>>> img = encoder.encode("hello python!", {'width':300})

>>> img.save("char.png")

char.png就是生成的二维码文件

二、用qrcode模块生成二维码

1、下载:https://pypi.python.org/packages/source/q/qrcode/qrcode-2.0.tar.gz

2、安装:tar -zxf qrcode-2.0.tar.gz && cd qrcode-2.0 && python setup.py install

3、用qrcode生成二维码

>>> import qrcode

>>> q=qrcode.main.QRCode()

>>> q.add_data("hello python!")

>>> q.make()

>>> m=q.make_image()

>>> m.save('char.png')

三、二维码的识别

解析二维码用到zbar模块,改模块在windowns下面是exe文件直接安装,比较简单,在linux下依赖的包比较多,安装过程就不在介绍,使用方法如下:

def get_QR():
scanner = zbar.ImageScanner()
scanner.parse_config("enable")
pil = Image.open("char.png").convert('L')
width, height = pil.size
raw = pil.tostring()
image = zbar.Image(width, height, 'Y800', raw)
scanner.scan(image)
data = ''
for symbol in image:
data+=symbol.data
del(image)
return data


data就是二维的内容

#coding:utf-8

'''

Python生成二维码 v1.0

主要将文本生成二维码图片

测试一:将文本生成白底黑字的二维码图片

测试二:将文本生成带logo的二维码图片

'''

__author__ = 'Xue'

import qrcode

from PIL import Image

import os

#生成二维码图片

def make_qr(str,save):

qr=qrcode.QRCode(

version=4, #生成二维码尺寸的大小 1-40 1:21*21(21+(n-1)*4)

error_correction=qrcode.constants.ERROR_CORRECT_M, #L:7% M:15% Q:25% H:30%

box_size=10, #每个格子的像素大小

border=2, #边框的格子宽度大小

)

qr.add_data(str)

qr.make(fit=True)

img=qr.make_image()

img.save(save)

#生成带logo的二维码图片

def make_logo_qr(str,logo,save):

#参数配置

qr=qrcode.QRCode(

version=4,

error_correction=qrcode.constants.ERROR_CORRECT_Q,

box_size=8,

border=2

)

#添加转换内容

qr.add_data(str)

#

qr.make(fit=True)

#生成二维码

img=qr.make_image()

#

img=img.convert("RGBA")

#添加logo

if logo and os.path.exists(logo):

icon=Image.open(logo)

#获取二维码图片的大小

img_w,img_h=img.size

factor=4

size_w=int(img_w/factor)

size_h=int(img_h/factor)

#logo图片的大小不能超过二维码图片的1/4

icon_w,icon_h=icon.size

if icon_w>size_w:

icon_w=size_w

if icon_h>size_h:

icon_h=size_h

icon=icon.resize((icon_w,icon_h),Image.ANTIALIAS)

#详见:http://pillow.readthedocs.org/handbook/tutorial.html

#计算logo在二维码图中的位置

w=int((img_w-icon_w)/2)

h=int((img_h-icon_h)/2)

icon=icon.convert("RGBA")

img.paste(icon,(w,h),icon)

#详见:http://pillow.readthedocs.org/reference/Image.html#PIL.Image.Image.paste

#保存处理后图片

img.save(save)

if __name__=='__main__':

save_path='theqrcode.png' #生成后的保存文件

logo='logo.jpg' #logo图片

str=raw_input('请输入要生成二维码的文本内容:')

#make_qr(str)

make_logo_qr(str,logo,save_path)

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: