本文作者:HelloGitHub-LITTLECHIEH
这是 HelloGitHub 推出的《讲解开源项目》系列,今天给大家推荐一个 Python 开源生成二维码的项目——qrcode
二维码又称二维条码,常见的二维码为 QR Code,QR 全称 Quick Response。是一个近几年来移动设备上超流行的一种编码方式,在现在的生活中二维码随处可见。我们可以用它支付、浏览网站等,为什么他会这么流行?下面说几个特点:
- 可存储的信息量大:可容纳多达 1850 个大写字母或 2710 个数字或 1108 个字节或 500 多个汉字。
- 容错能力强:具有纠错功能,这使得二维条码因穿孔、污损等引起局部损坏时,照样可以正确得到识读,损毁面积达 30% 仍可恢复信息。
- 译码可靠性高:它比普通条码译码错误率百万分之二要低得多,误码率不超过千万分之一。
- 激光可识别。
比如我们现在常见的公众号二维码,他就利用了二维码容错能力强的特点,在二维码中间加入了公众号的图标。虽然中间的图片遮盖了一部分二维码的真实数据,但因为其强大的容错能力,所以并没有影响二维码要传递的数据。
一图胜千言,好了这里二维码的基本知识就介绍完成了。
二维码是一个很方便的传递信息的载体,但是像上面黑白的二维码感觉非常缺少‘灵魂’。下面就介绍今天的主角:qrcode
这是一个由 Python 编写的二维码生成器,支持生成 GIF 动态、图片二维码,让你的二维码变得有趣起来。
为什么需要使用到这个二维码生成器来生成二维码呢?
-
使用简单:快速上手,仅需 2 行代码,即可开始使用!
-
在二维码中增加图片:可以让用户通过二维码中的图片,初步了解该二维码是和什么东西有关。(该二维码加入了 HG 的 logo)
-
在二维码中增加动图:通过动图,让二维码活过来。
-
使用方式多样:有以下的 3 种使用方式
- 命令行方式
- 导入文件方式(import)
- 可执行文件
-
用就对了:我不要你觉得,我要我觉得
滑稽
演示环境
操作系统:Windows | Python 版本:3.5
我们通过 Python 的 pip 包管理工具进行安装:
pip install myqr
注:此处可能需要升级 pip,升级命令
pip install --upgrade pip
安装完成之后,就可以直接在命令行中使用了!下面逐一讲解各种二维码的生成方法
首先生成一个普通二维码
-
打开 cmd
-
输入命令
myqr https://github.com -n helloword.png
参数
-n
:生成二维码的文件名
这样就会得到一个二维码图片,生成的图片保存在了当前目录,后面可以通过传入参数修改默认目录。
-
先准备一张图片放在目录下(方形的图片效果最好)
-
将图片名称修改为 github.jpg(后缀根据自己的照片格式而定)
-
在命令行中输入:
myqr https://github.com -n mypicture.png -p github.jpg -c
参数:
-n
:生成二维码的名称-p
:二维码加入的图片,支持 jpg、gif、png 格式-c
:选择是否生成彩色二维码,如果不设置默认为黑白- 更多参数请看下面附录部分
步骤和彩色二维码的方法一致,但是需要注意:
- 增加图片为 gif
- 修改生成二维码的后缀为 gif
从官方文档整理的常用参数如下:
-n
:生成二维码的名称-p
:二维码加入的图片,支持.jpg
、.gif
、.png
、.bmp
格式-c
:选择是否生成彩色二维码,如果不设置默认为黑白-v
:控制边长,范围是 1 至 40,数字越大边长越大-l
:控制纠错水平,范围是 L、M、Q、H 从左到右依次升高-d
:控制输出二维码的存储位置-con
:用以调节图片的对比度,1.0 表示原始图片,更小的值表示更低对比度,更大反之。默认为 1.0-bri
:用来调节图片的亮度,其余用法和取值与-con
相同
打开命令行有个小技巧,可以将 cmd 迅速切换到想要的目录,避免了切换盘符的麻烦:
二维码有以下几种分类
- 黑白和彩色码
- 黑白码
- 彩色码
- 融合和视觉码
- 艺术码
以上就是本篇文章的全部内容了,相信你对二维码更加了解了。并且对 qrcode 库的常用参数有了一定了解,那就快去生成一个有趣、有‘灵魂’的二维码吧!
有好玩的库,但不会用,看着干着急?欢迎告诉我们,同时也欢迎加入我们。我们的愿景: “让对开源感兴趣的人不再畏惧,开源项目的发起者不再孤单。”