zoukankan      html  css  js  c++  java
  • 手写笔记变PDF-Gooey几行代码变命令行程序为图形化界面

    前言

    最近发现了一个非常不错的Python类库————Gooey,
    https://github.com/chriskiehl/Gooey

    在它的帮助下我们可以非常方便的将一个命令行程序升级成一个图形化界面程序。
    https://www.cnblogs.com/wlzcool/p/13985073.html
    我们以之前的这个Python 图片合并pdf的命令行程序作为例子来进行讲解,希望能帮助到大家。

    安装

    最简单的办法就是用pip进行安装

    pip install Gooey  
    

    用法简介

    只需要在我们的代码方法开头加入@Gooey即可

    from gooey import Gooey
    
    @Gooey      <--- all it takes! :)
    def main():
      parser = ArgumentParser(...)
      # 其他代码 临时营地
    

    基础版本

    '''
    A simple Gooey example. One required field, one optional.
    '''
    
    from gooey import Gooey, GooeyParser
    
    
    @Gooey()
    def main():
        parser = GooeyParser(description='Process some integers.')
    
        parser.add_argument(
            'required_field',
            metavar='Some Field',
            help='Enter some text!')
    
        parser.add_argument(
            '-f', '--foo',
            metavar='Some Flag',
            action='store_true',
            help='I turn things on and off')
    
        parser.parse_args()
        print('Hooray!')
    
    
    if __name__ == '__main__':
        main()
    

    image.png
    可以看到我们这就已经生成了一个图形化界面,现在就让我们开始给这个程序增加需要的功能吧

    修改程序名称

    可以看到我们当前的程序名称是我们程序代码的名字,这样一点都不优雅,所以我们需要program_name来显示我们需要的名称。

    @Gooey(
        program_name='图片合并pdf',
    )
    

    更新目标程序

    我们使用的是我之前编写的一个命令行程序,它可以将一个文件夹中的图片整个变成一个PDF,
    https://juejin.cn/post/6971218428128411684
    对于经常需要把自己的手写笔记转成pdf的同学帮助很大,但是它是一个命令行程序,操作起来还是有点不太方便,这次我们就把它变成图形化界面程序。

    from PIL import Image
    import os
    import img2pdf
    
    flag = False
    while not flag:
        dirname = input("请输入图片文件夹所在路径(例如d:/wlzcool):")
        flag = os.path.exists(dirname)
        if not flag:
            print("图片文件夹所在路径不存在!")
    saveflag = False
    while not saveflag:
        savedirname = input("请输入目标图片文件夹所在路径(例如d:/wlzcool2):")
        saveflag = os.path.exists(savedirname)
        if not saveflag:
            print("图片文件夹所在路径不存在!")
            automakedir = input("是否自动创建对应文件夹?(是Y/否N):")
            if automakedir.strip().upper() == "Y":
                os.makedirs(savedirname)
                saveflag = True
    files = os.listdir(dirname)
    reductionFactor = int(input("请输入长宽压缩比(例如3):"))
    if reductionFactor <= 0:
        reductionFactor = 3
    isConvertBlack = input("是否输出黑白版本?(是Y/否N):").strip().upper() == "Y"
    for fname in files:
        if not fname.endswith(".jpg"):
            continue
        path = os.path.join(dirname, fname)
        savePath = os.path.join(savedirname, fname)
        if os.path.isdir(path):
            continue
        img = Image.open(path)    
        if img.size[0] > img.size[1]:
            im_rotate = img.rotate(90, expand=True)
            size = (int(im_rotate.size[0] / reductionFactor), int(im_rotate.size[1] / reductionFactor))
            im_rotate = im_rotate.resize(size)
            if isConvertBlack:
                im_rotate = im_rotate.convert("L")
            im_rotate.save(savePath, quality=95)
        else:
            size = (int(img.size[0] / reductionFactor), int(img.size[1] / reductionFactor))
            img = img.resize(size)
            if isConvertBlack:
                img = img.convert("L")
            img.save(savePath, quality=95)
    filename = input("请输入输出文件名(例如:第一章):")
    with open(filename + ".pdf", "wb") as f:
        imgs = []
        files = os.listdir(savedirname)
        for fname in files:
            if not fname.endswith(".jpg"):
                continue
            path = os.path.join(savedirname, fname)
            if os.path.isdir(path):
                continue
            imgs.append(path)
        f.write(img2pdf.convert(imgs))
    

    这是我们现有的代码,需要对其进行一些改造才可以符合我们的要求

    提取参数

    要想使用Gooey,首先我们得把我们的参数整个拿到最前面来,这样保证这里能够更加清晰的赋值。

    图片文件夹所在路径

    这个参数是我们要合并的图片所在的文件夹路径,我们对应的可以使用Gooey的DirChooser组件

    parser.add_argument('dirname', metavar='图片文件夹所在路径', help="例如d:/wlzcool", widget='DirChooser')
    

    image.png
    第一个dirname是参数的名称,第二个metavar是我们展示在前面的给用户看的,如果没有metavar的时候,第一个参数会展示到界面上。

    目标图片文件夹所在路径

    因为我们要将对应的图片进行一下批量处理,所以还需要一个用来保存处理后的图片的文件夹地址

    parser.add_argument('savedirname', metavar='目标图片文件夹所在路径', help="例如d:/wlzcool2", widget='DirChooser')
    

    图片长宽压缩比

    手机拍照的图片实在是太大了,需要进行一下压缩才能保证最后生成的文件大小不会过大。这个参数就是对传入的图片进行长宽压缩的,需要限制为正整数。

    parser.add_argument(
        'reductionFactor',
        metavar='长宽压缩比',
        help='例如3,需要填入大于等于1的整数',
        gooey_options={
            'validator': {
                'test': '1 <= int(user_input) ',
                'message': '长宽压缩比需大于等于1'
            }
        })
    

    这里面的gooey_options可以用来对用户输入的数据进行验证,如果不符合时会进行提示。

    image.png

    是否输出黑白版本

    有的时候不需要彩色版pdf,我们可以使用此选项来进行黑白版本的选择
    https://github.com/chriskiehl/GooeyExamples/blob/master/examples/widget_demo.py

    parser.add_argument(
        '-isConvertBlack', 
        metavar='是否输出黑白版本',
        action='store_true',
        help='需要输出黑白版本请勾选')
    

    需要注意的是,因为是否输出黑白这个勾选框是可选的,所以我们要在参数名这里增加一个-表示这是可选参数,另外需要注意因为我们的action是store_true,所以我们的参数isConvertBlack勾选后为True

    输出文件的文件名

    这里就是很简单的文本框,没有什么需要注意的部分

    parser.add_argument(
        'filename',
        metavar='请输入输出文件名',
        help='例如:第一章')
    

    添加About

    上面就介绍完所有的参数部分了,我们还可以给自己增加一个作者相关,将我们的相关信息放上去,哈哈。

    将程序转成可执行文件

    不是所有的电脑都有Python环境,我们需要将脚本打包成exe方便在任意一台电脑上使用。 使用 PyInstaller 来进行脚本的打包

    安装 PyInstaller

    pip install pyinstaller

    打包脚本

    在脚本所在的路径的cmd中执行以下命令即可

    pyinstaller -F -w yourprogram.py
    

    这里需要加上-w参数,这样才能保证最后生成的程序exe打开时不会出现控制台。

    最终成品

    image.png

    最终代码地址

    https://github.com/wlzcool/ImageToPdf

    生成的可执行程序

    如果不方便自己生成程序
    也可以从百度云下载
    链接: https://pan.baidu.com/s/1eLDaLUwJlztrhP6N_Y1DXQ 提取码: gtxm

    总结

    所以,我们今天又掌握了Gooey的用法,开心!给我们的程序换了个漂亮的界面,真的是非常赏心悦目哦。
    如果今天的文章对你有帮助,点个赞吧!

  • 相关阅读:
    阿里云图片在线处理
    下载文件
    adobe acrobat dc根据模板制作PDF问题总结点
    springcloud服务进行轮询采用Ribbon
    SpringCloud-Eureka-Client 启动后自动停止
    OI模板
    化学整理
    题解 P4180 [BJWC2010]严格次小生成树
    题解 CF255D 【Mr. Bender and Square】
    题解 P1541 【乌龟棋】
  • 原文地址:https://www.cnblogs.com/wlzcool/p/15031249.html
Copyright © 2011-2022 走看看