个性化二维码的exe桌面应用的获取方式我放在文章最后面了,注意查收。通过执行打包后的exe应用程序可以直接运行生成个性化二维码。
开始之前先来看一下通过二维码生成器是如何生成个性化二维码的。
【阅读全文】
文章图片
文章图片
其中使用的python包和之前的GUI应用制作使用的模块是一样的。
# -*- coding:utf-8 -*-
import osimport sysfrom PyQt5.QtWidgets import *from PyQt5.QtGui import *from PyQt5.QtCore import *import images
这里的images模块是用于解决打包应用时外部图片的引用不能生效的问题。后面的一篇文章中将会说明如何将外部资源打包到exe的应用中去。
做GUI的桌面应用,首先还是使用pyqt5进行界面的布局和界面组件的添加,虽然代码量看起来比较多,但逻辑不多。
# -*- coding:utf-8 -*-
def init_ui(self):
grid = QGridLayout()self.picture_name = ''
self.words_label = QLabel()
self.words_label.setText('链接设置:')
self.words_text = QLineEdit()
self.words_text.setPlaceholderText('www.baidu.com')
self.words_text.setAttribute(Qt.WA_InputMethodEnabled, False)self.version_label = QLabel()
self.version_label.setText('边距设置(只允许微调):')
self.version_text = QSpinBox()
self.version_text.setRange(1, 3)
self.version_text.setValue(1)self.picture_text = QLineEdit()
self.picture_text.setPlaceholderText('个性化图片路径')
self.picture_text.setReadOnly(True)
self.picture_button = QPushButton()
self.picture_button.setText('个性化图片')
self.picture_button.clicked.connect(self.picture_button_click)self.colorized_label = QLabel()
self.colorized_label.setText('是否显示为彩色:')
self.colorized_text = QComboBox()
colorized_items = ['是', '否']
self.colorized_text.addItems(colorized_items)
self.colorized_text.setCurrentIndex(1)self.brightness_label = QLabel()
self.brightness_label.setText('调节图片亮度:')
self.brightness_text = QDoubleSpinBox()
self.brightness_text.setRange(1, 10)
self.brightness_text.setSingleStep(1.0)self.save_dir_text = QLineEdit()
self.save_dir_text.setPlaceholderText('存储目录')
self.save_dir_text.setReadOnly(True)
self.save_dir_button = QPushButton()
self.save_dir_button.setText('自定义路径')
self.save_dir_button.clicked.connect(self.save_dir_button_click)self.generate_button = QPushButton()
self.generate_button.setText('快速生成二维码')
self.generate_button.clicked.connect(self.generate_button_click)self.version_current = QLabel()
self.version_current.setText('默认二维码为作者公众号,版本声明:本应用由公众号 [Python 集中营] 发布!')
self.version_current.setAlignment(Qt.AlignCenter)
self.version_current.setStyleSheet('color:red')self.image = QLabel()
self.image.setScaledContents(True)
self.image.setMaximumSize(200, 200)
self.image.setPixmap(QPixmap(':/default.png'))grid.addWidget(self.words_label, 0, 0, 1, 1)
grid.addWidget(self.words_text, 0, 1, 1, 2)
grid.addWidget(self.version_label, 1, 0, 1, 2)
grid.addWidget(self.version_text, 1, 2, 1, 1)
grid.addWidget(self.picture_text, 2, 0, 1, 2)
grid.addWidget(self.picture_button, 2, 2, 1, 1)
grid.addWidget(self.colorized_label, 3, 0, 1, 2)
grid.addWidget(self.colorized_text, 3, 2, 1, 1)
grid.addWidget(self.brightness_label, 4, 0, 1, 2)
grid.addWidget(self.brightness_text, 4, 2, 1, 1)
grid.addWidget(self.save_dir_text, 5, 0, 1, 2)
grid.addWidget(self.save_dir_button, 5, 2, 1, 1)
grid.addWidget(self.generate_button, 6, 0, 1, 3)hbox = QHBoxLayout()
hbox.addWidget(self.image)
hbox.addSpacing(30)
hbox.addLayout(grid)vbox = QVBoxLayout()
vbox.addLayout(hbox)
vbox.addSpacing(10)
vbox.addWidget(self.version_current)self.setLayout(vbox)
用到的槽函数有三个,一个是为了做选择背景图片、第二个是为了做选择要存储生成后的文件存放路径可以自由选择存放到什么地方、第三个是为了做调起生成二维码的函数。
第一个来看一下如何通过关联槽函数来实现读取需要作为个性化二维码的背景图片。
def picture_button_click(self):
import os
self.cwd = os.getcwd()
txt_file_path = QFileDialog.getOpenFileName(self, "选取文件", self.cwd, "JPG File (*.jpg);
;
PNG File (*.png)")
self.picture_text.setText(txt_file_path[0])
if self.picture_text.text().strip() != "":
self.picture_name = txt_file_path[0].split('/')[-1].split('.')[0]
print(self.picture_name)
else:
self.picture_name = ''
第二个就是选择存储文件路径的槽函数。
def save_dir_button_click(self):
import os
self.cwd = os.getcwd()
directory = QFileDialog.getExistingDirectory(self, '选取文件夹', self.cwd)
print(directory)
self.save_dir_text.setText(directory)
是通过dialog对话框的形式获取到自定义选择的存储文件路径。
第三个槽函数就是为了生成个性化二维码,其实二维码的生成部分只有一句代码。那就是MYQR模块提供的run函数,通过这个函数就能实现个性化二维码的生成。
首先,需要导入MYQR这个库。
from MyQR import myqr
为了可以看清楚后面二维码生成函数(run函数),先来看一下这个库提供的run函数都有什么参数。
'''
myqr.run()参数解释
words需要跳转的链接或者文字
version自然数,数字越大边长越大
level纠错等级
picture结合图片
colorized是否显示彩色
contrast对比度,默认为1.0
brightness亮度float,调节图片的亮度
save_name输出文件名,默认文件名"qrcode.png"
save_dir存储位置,默认存储当前目录
'''
下面看一下这个具体生成个性化二维码的槽函数。除了二维码的生成部分和需要将生成后的二维码放到应用的页面上展示之外,其他主要就是一些参数的校验方法。
def generate_button_click(self):
from MyQR import myqr
colorized_index = self.colorized_text.currentIndex()
print(colorized_index)
colorized = None
if colorized_index == 0:
colorized = True
else:
colorized = False
print(colorized)
words_text = self.words_text.text()
words = None
if words_text.strip() != "":
words = words_text.strip()
else:
words = 'default message: Python is very beautiful'
print(words)
version_text = self.version_text.value()
print(version_text)
picture_text = self.picture_text.text()
picture = None
if picture_text.strip() != "":
picture = picture_text
print(picture)
brightness_text = self.brightness_text.value()
print(brightness_text)
save_dir_text = self.save_dir_text.text()
save_dir = None
if save_dir_text.strip() != "":
save_dir = save_dir_text.strip()
else:
save_dir = os.getcwd()
print(save_dir)
myqr.run(words=str(words), version=int(version_text), level='H', picture=picture,
colorized=colorized, contrast=1.0, brightness=float(brightness_text), save_dir=save_dir)
if self.picture_name.strip() != '':
map_dir = save_dir + '/' + self.picture_name + '_qrcode.png'
else:
map_dir = save_dir + '/' + 'qrcode.png'
print(map_dir)
self.image.setPixmap(QPixmap(map_dir))
代码看起来比较多,仔细理一理也没有很难懂的逻辑处理。有问题或者有更好的处理方法可以在评论区留言大家一起讨论~
个性化二维码生成器的exe桌面应用获取方式:公众号内回复“二维码生成器”领取。由于代码篇幅较多,下一篇文章将介绍一下怎么可以将外部资源图片等打包进PyQt5的应用中。
文章图片
【往期精选】
如何在控制台实现一个数据管理系统(包括MYSQL数据库的增删改查)
自制文档格式转换器,支持 .txt/.xlsx/.csv格式转换...
PyPDF2如何实现按照PDF页码提取后并另存为PDF格式文件?
浪漫的turtle,送给程序员自己的圣诞树!
【pyqt5做了一个二维码生成器,已打包成exe可执行程序...】PyQt5 GUI:百度图片下载器(文末附源码)
推荐阅读
- 推荐系统论文进阶|CTR预估 论文精读(十一)--Deep Interest Evolution Network(DIEN)
- Python专栏|数据分析的常规流程
- Python|Win10下 Python开发环境搭建(PyCharm + Anaconda) && 环境变量配置 && 常用工具安装配置
- Python绘制小红花
- Pytorch学习|sklearn-SVM 模型保存、交叉验证与网格搜索
- OpenCV|OpenCV-Python实战(18)——深度学习简介与入门示例
- python|8. 文件系统——文件的删除、移动、复制过程以及链接文件
- 爬虫|若想拿下爬虫大单,怎能不会逆向爬虫,价值过万的逆向爬虫教程限时分享
- 分布式|《Python3网络爬虫开发实战(第二版)》内容介绍
- java|微软认真聆听了开源 .NET 开发社区的炮轰( 通过CLI 支持 Hot Reload 功能)