利用Python轻松生成艺术签名

目录
  • 一、写在前面
  • 二、先看看效果
  • 三、代码展示
    • 1.需要用到的模块
    • 2.窗口名字/图标/大小/布局
    • 3.必要组件的定义
    • 4.输入框
    • 5.保存/生成按钮
    • 6.下拉框
    • 7.组件布局
    • 8.事件绑定
    • 9.生成签名
    • 10.更新界面上的图片
    • 11.签名保存
    • 12.run
  • 四、全部代码

一、写在前面

很多兄弟觉得自己字写的不好什么的,没事,咱们直接用python来生成,对着多练练就能写出一手好看的艺术签名了,小姐姐看了直呼好看~

二、先看看效果

可以选择字体、颜色,这里我们用默认的看看的效果。

啊这,一笔学不来,算了,咱们敲代码吧…

三、代码展示

1.需要用到的模块

import requests
from PIL import Image
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
from PyQt5 import QtWidgets, QtGui

2.窗口名字/图标/大小/布局

self.setFixedSize(600, 500)
self.setWindowTitle('嗨学编程—艺术签名生成器')
self.setWindowIcon(QIcon('resource/icon/icon.jpg'))
self.grid = QGridLayout()

3.必要组件的定义

self.show_label = QLabel()
self.show_label.setScaledContents(True)
self.show_label.setMaximumSize(600, 400)
self.show_image = Image.open('resource/image/ori.jpg').convert('RGB')
self.updateimage()
self.show_image_ext = 'jpg'
self.name_label = QLabel('输入您的姓名:')
self.font_label = QLabel('艺术签名字体:')
self.color_label = QLabel('艺术签名颜色:')

4.输入框

self.name_edit = QLineEdit()
self.name_edit.setText('签名生成器')

5.保存/生成按钮

self.generate_button = QPushButton('生成艺术签名')
self.save_button = QPushButton('保存艺术签名')

6.下拉框

self.font_combobox = QComboBox()
for item in ['一笔艺术签', '连笔商务签', '一笔商务签', '真人手写', '暴躁字']:
    self.font_combobox.addItem(item)
self.color_combobox = QComboBox()
for item in ['Black', 'Blue', 'Red', 'Green', 'Yellow',
             'Pink', 'DeepSkyBlue', 'Cyan', 'Orange', 'Seashell']:
    self.color_combobox.addItem(item)

7.组件布局

self.grid.addWidget(self.show_label, 0, 0, 5, 5)
self.grid.addWidget(self.name_label, 5, 0, 1, 1)
self.grid.addWidget(self.name_edit, 5, 1, 1, 4)
self.grid.addWidget(self.font_label, 6, 0, 1, 1)
self.grid.addWidget(self.font_combobox, 6, 1, 1, 4)
self.grid.addWidget(self.color_label, 7, 0, 1, 1)
self.grid.addWidget(self.color_combobox, 7, 1, 1, 4)
self.grid.addWidget(self.generate_button, 8, 3, 1, 1)
self.grid.addWidget(self.save_button, 8, 4, 1, 1)
self.setLayout(self.grid)

8.事件绑定

self.generate_button.clicked.connect(self.generate)
self.save_button.clicked.connect(self.save)

9.生成签名

def generate(self):
    font2ids_dict = {
                        '一笔艺术签': ['901', '15'],
                        '连笔商务签': ['904', '15'],
                        '一笔商务签': ['905', '14'],
                        '真人手写': ['343', '14'],
                        '卡通趣圆字': ['397', '14'],
                        '暴躁字': ['380', '14']
                }
    color2ids_dict = {
                        'Black': ['#000000', '#FFFFFF'],
                        'Blue': ['#0000FF', '#FFFFFF'],
                        'Red': ['#FF0000', '#FFFFFF'],
                        'Green': ['#00FF00', '#FFFFFF'],
                        'Yellow': ['#FFFF00', '#FFFFFF'],
                        'Pink': ['#FFC0CB', '#FFFFFF'],
                        'DeepSkyBlue': ['#00BFFF', '#FFFFFF'],
                        'Cyan': ['#00FFFF', '#FFFFFF'],
                        'Orange': ['#FFA500', '#FFFFFF'],
                        'Seashell': ['#FFF5EE', '#FFFFFF']
                    }
    url = 'http://www.jiqie.com/a/re14.php'
    headers = {
                'Referer': 'http://www.jiqie.com/a/14.htm',
                'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.129 Safari/537.36',
                'Host': 'www.jiqie.com',
                'Origin': 'http://www.jiqie.com'
            }
    ids_0 = font2ids_dict[self.font_combobox.currentText()]
    ids_1 = color2ids_dict[self.color_combobox.currentText()]
    data = {
                'id': self.name_edit.text(),
                'zhenbi': '20191123',
                'id1': ids_0[0],
                'id2': ids_0[1],
                'id3': ids_1[0],
                'id5': ids_1[1]
            }
    res = requests.post(url, headers=headers, data=data)
    image_url = re.findall(r'src="(.*?)"', res.text)[0]
    self.show_image_ext = image_url.split('.')[-1].split('?')[0]
    res = requests.get(image_url)
    fp = open('tmp.%s' % self.show_image_ext, 'wb')
    fp.write(res.content)
    fp.close()
    self.show_image = Image.open('tmp.%s' % self.show_image_ext).convert('RGB')
    self.updateimage()
    os.remove('tmp.%s' % self.show_image_ext)

10.更新界面上的图片

def updateimage(self):
    if self.show_image is None:
        return
    fp = io.BytesIO()
    self.show_image.save(fp, 'JPEG')
    qtimage = QtGui.QImage()
    qtimage.loadFromData(fp.getvalue(), 'JPEG')
    qtimage_pixmap = QtGui.QPixmap.fromImage(qtimage)
    self.show_label.setPixmap(qtimage_pixmap)

11.签名保存

def save(self):
    if self.show_image is None:
        return
    filename = QFileDialog.getSaveFileName(self, '保存', './sign.%s' % self.show_image_ext, '所有文件(*)')
    if filename[0]:
        self.show_image.save(filename[0])
        QDialog().show()

12.run

if __name__ == '__main__':
    app = QApplication(sys.argv)
    gui = ArtSignGenerator()
    gui.show()
    sys.exit(app.exec_())

四、全部代码

我从来不吝啬源码,都直接放出来,不像那些,哈哈哈,懂的都懂。

import os
import re
import io
import sys
import requests
from PIL import Image
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
from PyQt5 import QtWidgets, QtGui

class ArtSignGenerator(QWidget):
    def __init__(self, parent=None):
        super(ArtSignGenerator, self).__init__(parent)
        self.setFixedSize(600, 500)
        self.setWindowTitle('嗨学编程—艺术签名生成器')
        self.setWindowIcon(QIcon('resource/icon/icon.jpg'))
        self.grid = QGridLayout()

        self.show_label = QLabel()
        self.show_label.setScaledContents(True)
        self.show_label.setMaximumSize(600, 400)
        self.show_image = Image.open('resource/image/ori.jpg').convert('RGB')
        self.updateimage()
        self.show_image_ext = 'jpg'
        self.name_label = QLabel('输入您的姓名:')
        self.font_label = QLabel('艺术签名字体:')
        self.color_label = QLabel('艺术签名颜色:')

        self.name_edit = QLineEdit()
        self.name_edit.setText('签名生成器')

        self.generate_button = QPushButton('生成艺术签名')
        self.save_button = QPushButton('保存艺术签名')

        self.font_combobox = QComboBox()
        for item in ['一笔艺术签', '连笔商务签', '一笔商务签', '真人手写', '暴躁字']:
            self.font_combobox.addItem(item)
        self.color_combobox = QComboBox()
        for item in ['Black', 'Blue', 'Red', 'Green', 'Yellow', 
                     'Pink', 'DeepSkyBlue', 'Cyan', 'Orange', 'Seashell']:
            self.color_combobox.addItem(item)

        self.grid.addWidget(self.show_label, 0, 0, 5, 5)
        self.grid.addWidget(self.name_label, 5, 0, 1, 1)
        self.grid.addWidget(self.name_edit, 5, 1, 1, 4)
        self.grid.addWidget(self.font_label, 6, 0, 1, 1)
        self.grid.addWidget(self.font_combobox, 6, 1, 1, 4)
        self.grid.addWidget(self.color_label, 7, 0, 1, 1)
        self.grid.addWidget(self.color_combobox, 7, 1, 1, 4)
        self.grid.addWidget(self.generate_button, 8, 3, 1, 1)
        self.grid.addWidget(self.save_button, 8, 4, 1, 1)
        self.setLayout(self.grid)

        self.generate_button.clicked.connect(self.generate)
        self.save_button.clicked.connect(self.save)

    def generate(self):
        font2ids_dict = {
                            '一笔艺术签': ['901', '15'],
                            '连笔商务签': ['904', '15'],
                            '一笔商务签': ['905', '14'],
                            '真人手写': ['343', '14'],
                            '卡通趣圆字': ['397', '14'],
                            '暴躁字': ['380', '14']
                    }
        color2ids_dict = {
                            'Black': ['#000000', '#FFFFFF'],
                            'Blue': ['#0000FF', '#FFFFFF'],
                            'Red': ['#FF0000', '#FFFFFF'],
                            'Green': ['#00FF00', '#FFFFFF'],
                            'Yellow': ['#FFFF00', '#FFFFFF'],
                            'Pink': ['#FFC0CB', '#FFFFFF'],
                            'DeepSkyBlue': ['#00BFFF', '#FFFFFF'],
                            'Cyan': ['#00FFFF', '#FFFFFF'],
                            'Orange': ['#FFA500', '#FFFFFF'],
                            'Seashell': ['#FFF5EE', '#FFFFFF']
                        }
        url = 'http://www.jiqie.com/a/re14.php'
        headers = {
                    'Referer': 'http://www.jiqie.com/a/14.htm',
                    'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.129 Safari/537.36',
                    'Host': 'www.jiqie.com',
                    'Origin': 'http://www.jiqie.com'
                }
        ids_0 = font2ids_dict[self.font_combobox.currentText()]
        ids_1 = color2ids_dict[self.color_combobox.currentText()]
        data = {
                    'id': self.name_edit.text(),
                    'zhenbi': '20191123',
                    'id1': ids_0[0],
                    'id2': ids_0[1],
                    'id3': ids_1[0],
                    'id5': ids_1[1]
                }
        res = requests.post(url, headers=headers, data=data)
        image_url = re.findall(r'src="(.*?)"', res.text)[0]
        self.show_image_ext = image_url.split('.')[-1].split('?')[0]
        res = requests.get(image_url)
        fp = open('tmp.%s' % self.show_image_ext, 'wb')
        fp.write(res.content)
        fp.close()
        self.show_image = Image.open('tmp.%s' % self.show_image_ext).convert('RGB')
        self.updateimage()
        os.remove('tmp.%s' % self.show_image_ext)

    def updateimage(self):
        if self.show_image is None:
            return
        fp = io.BytesIO()
        self.show_image.save(fp, 'JPEG')
        qtimage = QtGui.QImage()
        qtimage.loadFromData(fp.getvalue(), 'JPEG')
        qtimage_pixmap = QtGui.QPixmap.fromImage(qtimage)
        self.show_label.setPixmap(qtimage_pixmap)

    def save(self):
        if self.show_image is None:
            return
        filename = QFileDialog.getSaveFileName(self, '保存', './sign.%s' % self.show_image_ext, '所有文件(*)')
        if filename[0]:
            self.show_image.save(filename[0])
            QDialog().show()

if __name__ == '__main__':
    app = QApplication(sys.argv)
    gui = ArtSignGenerator()
    gui.show()
    sys.exit(app.exec_())

以上就是利用Python轻松生成艺术签名的详细内容,更多关于Python艺术签名的资料请关注我们其它相关文章!

(0)

相关推荐

  • Python GUI Tkinter简单实现个性签名设计

    一.Tkinter的介绍和简单教程 Tkinter 是 Python 的标准 GUI 库.Python 使用 Tkinter 可以快速的创建 GUI 应用程序. 由于 Tkinter 是内置到 python 的安装包中.只要安装好 Python 之后就能 import Tkinter 库.而且 IDLE 也是用 Tkinter 编写而成.对于简单的图形界面 Tkinter 还是能应付自如. 注意:Python3.x 版本使用的库名为 tkinter,即首写字母 T 为小写. import tki

  • python3个性签名设计实现代码

    本文实例为大家分享了python个性签名设计的具体代码,供大家参考,具体内容如下 参考博客:Python GUI Tkinter简单实现个性签名设计 参考博客:python3爬虫之设计签名小程序 Code from tkinter import * from tkinter import messagebox import requests import re from PIL import Image,ImageTk #模拟浏览器发送请求 def download(): startUrl =

  • python如何爬取个性签名

    思路 改进原博主文章(Python GUI–Tkinter简单实现个性签名设计)的代码,原先的代码是基于Python2的,我这份代码基于Python3 并针对当前的网站做了相应调整 前置要求 Python 3.X tkinter PIL 完整代码 # -*- coding:utf-8 -*- from tkinter import * import tkinter import requests import re from PIL import Image def download(): st

  • python3爬虫之设计签名小程序

    本文实例为大家分享了python3设计签名小程序的具体代码,供大家参考,具体内容如下 首先,上一下要做的效果图: 先是这样一个丑陋的界面(我尽力了的真的!) 然后随便输入名字 然后点击按钮会显示出对应的个性签名: 这个是怎么实现的呢? 其实这个是将一个签名网站http://www.uustv.com/的内容爬下来显示了而已: 源代码如下: from tkinter import * import requests from tkinter import messagebox import re

  • python爬取个性签名的方法

    本文实例为大家分享了python爬取个性签名的具体代码,具体内容如下 #coding:utf-8 #import tkinter from tkinter import * from tkinter import messagebox import requests import re from PIL import Image def download(): start_url = 'http://www.uustv.com/' name = entry.get().encode('utf-8

  • Python库学习Tkinter制作GUI个性签名设计软件

    目录 Tkinter简介 获取个性签名图 设计软件GUI界面 下拉列表框 设计界面 人生苦短,快学Python! 上一周发了一篇文章<Python Tkinter图形工具使用方法及实例解析>,很多小伙伴都希望能多出点教程,今天就来了. Tkinter简介 由于Tkinter是Python自带的标准库,我们想要使用它的时候,只需直接导入即可. from tkinter import * Tkinter支持的组件有: 对于简单的图形界面 Tkinter 还是能应付自如,不过相对于PyQt5做出的界

  • 利用Python轻松生成艺术签名

    目录 一.写在前面 二.先看看效果 三.代码展示 1.需要用到的模块 2.窗口名字/图标/大小/布局 3.必要组件的定义 4.输入框 5.保存/生成按钮 6.下拉框 7.组件布局 8.事件绑定 9.生成签名 10.更新界面上的图片 11.签名保存 12.run 四.全部代码 一.写在前面 很多兄弟觉得自己字写的不好什么的,没事,咱们直接用python来生成,对着多练练就能写出一手好看的艺术签名了,小姐姐看了直呼好看~ 二.先看看效果 可以选择字体.颜色,这里我们用默认的看看的效果. 啊这,一笔学

  • 利用Python轻松实现视频转GIF动图

    目录 前言 1. 准备工作 2. 初探 3. 截取区域转动图 4. 固定区域转动图 5. 添加自定义文本 前言 不知道大家是不是有过类似的经历,在看视频的时候觉得某段非常有意思想弄成动图,但是无从下手! 或可以在网上找一些在线工具但是多多少少需要付费或者带有水印之类的,那么!? 对,今天我们就来学习用Python搞定这一需求吧! 动图效果 1. 准备工作 需要准备用于生成gif的视频文件,我这里用的是上次<用Python制作一个B站视频下载小工具>里案例中的视频.另外,就是需要用到moviep

  • 利用Python批量生成任意尺寸的图片

    实现效果 通过源图片,在当前工作目录的/img目录下生成1000张,分别从1*1到1000*1000像素的图片. 效果如下: 目录结构 实现示例 # -*- coding: utf-8 -*- import threading from PIL import Image image_size = range(1, 1001) def start(): for size in image_size: t = threading.Thread(target=create_image, args=(s

  • 利用python自动生成docker nginx反向代理配置

    利用python自动生成docker nginx反向代理配置 由于在测试环境上用docker部署了多个应用,而且他们的端口有的相同,有的又不相同,数量也比较多,在使用jenkins发版本的时候,不好配置,于是想要写一个脚本,能在docker 容器创建.停止的时候,自动生成nginx反向代理,然后reload nginx 我的原则是尽量简单,轻量,内存占用少 目标很明确,只要能监听到docker的容器启动/停止事件,即可 网上查了一下可以用docker events来监听docker事件,试了一下

  • 利用 Python ElementTree 生成 xml的实例

    Python 处理 xml 文档的方法有很多,除了经典的 sax 和 dom 之外,还有一个 ElementTree. 首先 import 之: from xml.etree import ElementTree as etree 然后开始构建 xml 树: from xml.etree.ElementTree import Element, SubElement, ElementTree # 生成根节点 root = Element('root') # 生成第一个子节点 head head =

  • 利用Python自动化生成爱豆日历详解

    目录 1.科普 2.爱豆日历 3.总结 本次内容有感于<Python编程快速上手-让繁琐工作自动化>. 根据书中的「处理Excel电子表格」章节内容,做出一份专属日历. 使用的模块为openpyxl,一个能读取和修改Excel电子表格的Pyhton模块. 实现自动化处理表格信息,摆脱无趣无味. 此外还有calendar模块,通过该模块生成日历信息. 最后利用openpyxl和calendar库,实现自动化生成爱豆日历. 1.科普 在进行代码操作前,简单对相关知识做个简单的学习. 一个Excel

  • 利用Python自动生成PPT的示例详解

    在日常工作中,PPT制作是常见的工作,如果制作创意类PPT,则无法通过自动化的形式生成,因为创意本身具有随机性,而自动化解决的是重复性工作,两者有所冲突. python-pptx是python处理PPT的一个库,注重的是读和写,无法导出,没有渲染功能. 废话不多说,第一步,安装python-pptx库: pip3 install -i https://pypi.doubanio.com/simple/ python-pptx ppt里面处理的主要对象一般为文本框,表格,图片. 每一页的ppt为一

  • 利用Python如何生成hash值示例详解

    一.介绍 如果在Python中需要对用户输入的密码或者其他内容进行加密,首选的方法是生成hash值. 在Python中可以利用二个模块来进行: - crypt - hashlib 二.crypt (一)crypt的主要方法和常量 名称 描述 md5(-) 利用md5算法加密 sha1(-) 利用sha1算法加密 sha224(-) 利用sha224算法加密 sha256(-) 利用sha256算法加密 sha384(-) 利用sha384算法加密 sha512(-) 利用sha512算法加密 (

  • 利用Python脚本生成sitemap.xml的实现方法

    安装lxml 首先需要pip install lxml安装lxml库. 如果你在ubuntu上遇到了以下错误: #include "libxml/xmlversion.h" compilation terminated. error: command 'x86_64-linux-gnu-gcc' failed with exit status 1 ---------------------------------------- Cleaning up... Removing tempo

  • 利用Python如何生成随机密码

    本位实例为大家分享了Python生成随机密码的实现过程,供大家参考,具体内容如下 写了个程序,主要是用来检测MySQL数据库的空密码和弱密码的, 在这里,定义了三类弱密码: 1. 连续数字,譬如123456,在get_weak_num中实现 2. 连续字母,譬如abcdef,在get_weak_character中实现 当然,个数都是随机的. 3. 数字和字母随机组合.在get_weak_num_character中实现. 同时定义了一个password_exist的列表,用于保存不同的密码.如

随机推荐