用python写一个自动生成春联的软件,打包exe,打包好的放在最后了

唠叨一下

年前Python写对联挺火的,但是代码又不是人人都用,那就直接写个界面打包一下呗~

主要实现只要运行后输入上联下联、横批,然后自动生成春联保存在代码文件夹,如果要打印出来也是可以的。

只要软件的兄弟,我放在最后了

效果展示

输入对联,选择路径后点击开始生成春联即可。

用python写一个自动生成春联的软件,打包exe,打包好的放在最后了

; 代码

需要导入的模块

网络数据获取相关模块
import io  # python IO 处理模块
from PIL import Image  # 图像处理模块
import requests  # 网络请求模块

UI 相关模块
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *
from PyQt5.QtGui import *

主题样式模块引用
from QCandyUi import CandyWindow

应用操作相关模块
import sys
import os
#兄弟们学习python,有时候不知道怎么学,从哪里开始学。掌握了基本的一些语法或者做了两个案例后,不知道下一步怎么走,不知道如何去学习更加高深的知识。
#那么对于这些大兄弟们,我准备了大量的免费视频教程,PDF电子书籍,以及视频源的源代码!
#还会有大佬解答!
#都在这个群里了 924040232
#欢迎加入,一起讨论 一起学习!

获取文字主题

def run(self):
    up_text = self.parent.up_text.text().strip()
    down_text = self.parent.down_text.text().strip()
    h_text = self.parent.h_text.text().strip()
    save_path = self.parent.save_path.text().strip()
    if up_text == '' or down_text == '' or h_text == '' or save_path == '':
        self.trigger.emit('参数设置不允许为空,请设置好后重新开始!')
        self.finished.emit(True)
    else:
        text = up_text + ' ' + down_text
        self.generate_image(text, layout='V', pre=0.75, out_file=save_path + '/上下联.jpg')
        self.generate_image(h_text, layout='H', pre=0.75, out_file=save_path + '/横批.jpg')
        self.finished.emit(True)

图片、文字获取
这部分参考了天元浪子的写对联

def get_word_image(self, ch='bg', pre=1.0):
        '''
        单文字图片下载函数
        :param ch: 默认网络请求参数'bg'
        :param pre: 单个文字对象
        :return: 图像对象
        '''
        res = io.BytesIO(requests.post(url='http://xufive.sdysit.com/tk', data={'ch': ch}).content)
        image = Image.open(res)
        w, h = image.size
        w, h = int(w * float(pre)), int(h * float(pre))
        return image.resize((w, h))  # 单个文字的形状是正方形,所以这里的长、宽都是一致的

生成对联

def generate_image(self, words, layout='V', pre=1.0, out_file=None):
        '''
        :param words: 春联文本
        :param layout: 布局:水平/垂直
        :param pre: 春联比例
        :param out_file: 保存文件
        :return:
        '''
        quality = 'H'
        if pre == 0.75:
            quality = 'M'
        elif pre == 0.5:
            quality = 'L'
        usize = {'H': (640, 23), 'M': (480, 18), 'L': (320, 12)}
        bg_im = self.get_word_image(ch='bg', pre=pre)
        self.trigger.emit('春联背景下载完成!')
        text_list = [list(item) for item in words.split()]
        rows = len(text_list)
        cols = max([len(item) for item in text_list])

        if layout == 'V':
            ow, oh = 40 + rows * usize[quality][0] + (rows - 1) * 10, 40 + cols * usize[quality][0]
        else:
            ow, oh = 40 + cols * usize[quality][0], 40 + rows * usize[quality][0] + (rows - 1) * 10
        out_im = Image.new('RGBA', (ow, oh), '#f0f0f0')

        for row in range(rows):
            if layout == 'V':
                row_im = Image.new('RGBA', (usize[quality][0], cols * usize[quality][0]), 'white')
                offset = (ow - (usize[quality][0] + 10) * (row + 1) - 10, 20)
            else:
                row_im = Image.new('RGBA', (cols * usize[quality][0], usize[quality][0]), 'white')
                offset = (20, 20 + (usize[quality][0] + 10) * row)

            for col, ch in enumerate(text_list[row]):
                if layout == 'V':
                    pos = (0, col * usize[quality][0])
                else:
                    pos = (col * usize[quality][0], 0)
                ch_im = self.get_word_image(ch=ch, pre=pre)
                row_im.paste(bg_im, pos)
                row_im.paste(ch_im, (pos[0] + usize[quality][1], pos[1] + usize[quality][1]), mask=ch_im)

            out_im.paste(row_im, offset)
        self.trigger.emit('春联图片拼装完成!')

        if out_file:
            out_im.convert('RGB').save(out_file)
            self.trigger.emit('春联保存成功!')

UI部分代码

class GenerateScroll(QWidget):
    def __init__(self):
        super(GenerateScroll, self).__init__()
        self.init_ui()

    def init_ui(self):
        self.setWindowTitle('春联生成器')
        self.setWindowIcon(QIcon('春联.ico'))

        vbox_main = QVBoxLayout()

        self.image_label = QLabel()
        self.image_label.setScaledContents(True)
        self.image_label.setMaximumSize(650,150)
        self.image_label.setPixmap(QPixmap('横批演示.png'))

        hbox = QHBoxLayout()
        self.brower = QTextBrowser()
        self.brower.setFont(QFont('宋体', 8))
        self.brower.setReadOnly(True)
        self.brower.setPlaceholderText('信息展示区域')
        self.brower.ensureCursorVisible()

        form = QFormLayout()

        self.up_label = QLabel()
        self.up_label.setText('设置上联')

        self.up_text = QLineEdit()
        self.up_text.setPlaceholderText('请输入上联')

        self.down_label = QLabel()
        self.down_label.setText('设置下联')

        self.down_text = QLineEdit()
        self.down_text.setPlaceholderText('请输入下联')

        self.h_label = QLabel()
        self.h_label.setText('设置横批')

        self.h_text = QLineEdit()
        self.h_text.setPlaceholderText('请输入横批')

        self.thread_ = WorkThread(self)
        self.thread_.trigger.connect(self.update_log)
        self.thread_.finished.connect(self.finished)

        self.save_path = QLineEdit()
        self.save_path.setReadOnly(True)

        self.save_btn = QPushButton()
        self.save_btn.setText('存储路径')
        self.save_btn.clicked.connect(self.save_btn_click)

        form.addRow(self.up_label, self.up_text)
        form.addRow(self.down_label, self.down_text)
        form.addRow(self.h_label, self.h_text)
        form.addRow(self.save_path, self.save_btn)

        vbox = QVBoxLayout()

        self.start_btn = QPushButton()
        self.start_btn.setText('开始生成春联')
        self.start_btn.clicked.connect(self.start_btn_click)

        vbox.addLayout(form)
        vbox.addWidget(self.start_btn)

        hbox.addWidget(self.brower)
        hbox.addLayout(vbox)

        vbox_main.addWidget(self.image_label)
        vbox_main.addLayout(hbox)

        self.setLayout(vbox_main)

槽函数,向文本浏览器中写入内容。

def update_log(self, text):
        '''
        :param text:
        :return:
        '''
        cursor = self.brower.textCursor()
        cursor.movePosition(QTextCursor.End)
        self.brower.append(text)
        self.brower.setTextCursor(cursor)
        self.brower.ensureCursorVisible()

    def save_btn_click(self):
        dicr = QFileDialog.getExistingDirectory(self, '选择文件夹', os.getcwd())
        self.save_path.setText(dicr)

    def start_btn_click(self):
        self.start_btn.setEnabled(False)
        self.thread_.start()

    def finished(self, finished):
        if finished is True:
            self.start_btn.setEnabled(True)
            h_image = self.save_path.text().strip() + '/横批.jpg'
            if os.path.isfile(h_image):
                self.image_label.setPixmap(QPixmap(h_image))
            self.update_log('由于上下联不好预览,请使用图片查看器预览,目前仅支持横批图片预览...')

打包exe可执行文件

以cmd为例

win+r打开运行框,输入cmd,按回车。

弹出命令提示符窗口后输入 pip install pyinstaller 安装这个pyinstaller模块

然后查看你的代码存放目录,复制下来,在命令提示符窗口切换目录。

如切换到D盘 输入 d: 这样就切换成功了。

用python写一个自动生成春联的软件,打包exe,打包好的放在最后了
输入 cd 将你的代码存放地址粘贴进去
用python写一个自动生成春联的软件,打包exe,打包好的放在最后了
这样就切换到你的代码存放目录了

然后输入 pyinstaller -F -w -i 图标名称.ico 代码文件名.py

如:pyinstaller -F -w -i aaa.ico zzz.py

等待打包完成即可

完整代码和exe软件我都放在蓝奏云了,直接获取
https://wwi.lanzoul.com/b03ufjvnc 密码:1024

Original: https://www.cnblogs.com/hahaa/p/15881282.html
Author: 轻松学Python
Title: 用python写一个自动生成春联的软件,打包exe,打包好的放在最后了

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/814974/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • 【Python】np.expand_dims()理解及实践

    1.概念:根据英文,可以简单理解为 扩展数组的shape。 2.理解: shape如何改变?数组内如何改变? import numpy as np a = np.array([[[…

    Python 2023年8月23日
    079
  • 多远线性算法预测房价

    一、基于统计分析库statsmodels 1.数据读取 import pandas as pd import numpy as np import seaborn as sns i…

    Python 2023年8月8日
    061
  • 解决pandas读取excel文件出错

    Traceback (most recent call last):File “c:/Users/Admin/Desktop/读取文件.py”, line …

    Python 2023年8月20日
    079
  • 通过VS下载的NuGet包,如何修改其下载存放路径?

    我们通过NuGet包管理器下载的引用包,默认是存放在C盘的,存储路径一般是: C:\Users\{系统用&…

    Python 2023年10月22日
    0141
  • ICCV, ECCV, CVPR,IEEE的关系

    计算机视觉领域世界三大顶级会议分别为CVPR、ICCV和ECCV。 ; CVPR CVPR,英文全称IEEE Conference on Computer Vision and P…

    Python 2023年10月24日
    0112
  • TFRecord的Shuffle、划分和读取

    对数据集的shuffle处理需要设置相应的buffer_size参数,相当于需要将相应数目的样本读入内存,且这部分内存会在训练过程中一直保持占用。完全的shuffle需要将整个数据…

    Python 2023年10月28日
    069
  • Django的simple_tag

    Django的simple_tag 原创 wx5e6caa8b9792d2022-08-01 17:13:32博主文章分类:Python自动化开发 ©著作权 文章标签 传参数 ht…

    Python 2023年5月24日
    089
  • 如何使用递归,递归使用的技巧详解

    弄明白递归 什么是递归 编写递归的技巧 递归的缺点 来几个栗子 1、斐波那契数列 2、兔子繁衍问题 3、青蛙跳台阶问题 4、汉诺塔问题 5、二叉树的遍历 总结 参考 弄明白递归 先…

    Python 2023年10月17日
    086
  • django多后端发送邮件

    django多后端发送邮件 精选原创 oaixnah_2022-08-10 17:41:16博主文章分类:django ©著作权 文章标签 django 自定义 邮件服务器 文章分…

    Python 2023年5月24日
    0105
  • 四层负载均衡 & 七层负载均衡

    负载均衡,一般是指将客户端流量分配到不同服务器上的一个服务。他的功能一般有三个: 将客户端请求分配到多个服务器 保证分配请求时本身高可用,且被分配的服务都是可用的 根据需求,弹性增…

    Python 2023年11月7日
    095
  • Python之进程+线程+协程(同步对象、信号量、队列)

    文章目录 ​​Event同步对象​​ ​​semaphore信号量​​ ​​队列​​ 本篇是关于Python进程方面的内容了,主要是Event同步对象,信号量和队列 Event同步…

    Python 2023年5月24日
    0126
  • python怎么定义y轴_在matplotlib中设置y轴限制

    我需要帮助设置matplotlib上的y轴限制。这是我尝试过的代码,但没有成功。 import matplotlib.pyplot as plt plt.figure(1, fig…

    Python 2023年9月5日
    089
  • pandas数据分析(二)开始了解数据

    上篇根据自己实际工作内容,写了一个简单的程序,用于读取csv文件,简单处理后输出到excel文件。接下来想更多更深入地使用pandas进行数据分析,其实最缺的是各种各样的数据集。搜…

    Python 2023年8月6日
    055
  • 我的错误

    var app = new Vue({ el: "#app", data: { movie_data:[], }, // 页面加在之前 会执行的函数 creat…

    Python 2023年6月12日
    078
  • django+vue项目跨域问题

    1.开发调式问题,路由指向(跨域问题)(1)前端vue,修改config目录下面的index.js 修改:proxyTable: {‘/’: {target…

    Python 2023年8月5日
    076
  • 人到中年,做管理真的需要懂的管理必备知识

    课堂三点要求: 认真听讲,记笔记 * – 讲义电子版会给补充,不要急于找资料 – 跟着课堂节奏 积极参与课堂互动,远程依然有温度 * – 课堂提…

    Python 2023年6月3日
    0106
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球