Python 实现自动完成A4标签排版打印功能


Posted in Python onApril 09, 2020

老婆大人让俺帮她通过Excel生成百人的准考证,她们学校打算来一次高考模拟。由于高考改革,每个学生的考试科目不一样,需要自动生成一下。

我一个程序员平时很少用到Excel,自己也不打算深入研究这个软件。如何解决她的需求呢?我直接想到了python,无所不能的python肯定可以搞定这个小case。

解决思路

数据处理:这个很简单的

生成可打印的文件

这个有些难度,我首先想到生成word。而且python也有word包来解决,不过后来想了一下,这个方案有问题。word结构不开源,格式和样式处理起来应该有问题。另外word在国外不普遍,遇到问题解决方案肯定不多。而PDF却不同,PDF在国外应用广使用人多,肯定好解决。

寻找方案

通过python 生成 pdf的方案确定后,果然通过Google找到了pylabels这个库。

如何解决

第一步安装库

pip install pylabels

第二步 执行下面的代码

import labels
from reportlab.graphics import shapes
 
specs = labels.Specification(210, 297, 2, 8, 90, 25, corner_radius=2)
 
def draw_label(label, width, height, obj):
 
label.add(shapes.String(2, 2, str(obj), fontName="Helvetica", fontSize=40))
 
# Create the sheet.
sheet = labels.Sheet(specs, draw_label, border=True)
 
# Add a couple of labels.
sheet.add_label("Hello")
sheet.add_label("World")
 
# We can also add each item from an iterable.
sheet.add_labels(range(3, 22))
 
sheet.add_label("Oversized label here")
 
# Save the file and we are done.
sheet.save('basic.pdf')
print("{0:d} label(s) output on {1:d} page(s).".format(sheet.label_count, sheet.page_count))

数据处理部分我就不分享了,就是简单的读取csv文件。

以上这篇Python 实现自动完成A4标签排版打印功能就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python正则表达式分组概念与用法详解
Jun 24 Python
python+opencv识别图片中的圆形
Mar 25 Python
python利用smtplib实现QQ邮箱发送邮件
May 20 Python
python爬取网页转换为PDF文件
Jun 07 Python
Python设计模式之状态模式原理与用法详解
Jan 15 Python
通过shell+python实现企业微信预警
Mar 07 Python
python 绘制拟合曲线并加指定点标识的实现
Jul 10 Python
Tensorflow中k.gradients()和tf.stop_gradient()用法说明
Jun 10 Python
python如何输出反斜杠
Jun 18 Python
Python3.9新特性详解
Oct 10 Python
解决PyCharm无法使用lxml库的问题(图解)
Dec 22 Python
pytorch 如何使用batch训练lstm网络
May 28 Python
python网络编程:socketserver的基本使用方法实例分析
Apr 09 #Python
Python使用扩展库pywin32实现批量文档打印实例
Apr 09 #Python
python3 自动打印出最新版本执行的mysql2redis实例
Apr 09 #Python
python实现处理mysql结果输出方式
Apr 09 #Python
python读取配置文件方式(ini、yaml、xml)
Apr 09 #Python
python数据分析工具之 matplotlib详解
Apr 09 #Python
使用python检查yaml配置文件是否符合要求
Apr 09 #Python
You might like
?算你??的 PHP 程式大小
2006/12/06 PHP
浅析php插件 Simple HTML DOM 用DOM方式处理HTML
2013/07/01 PHP
ThinkPHP内置jsonRPC的缺陷分析
2014/12/18 PHP
php解决和避免form表单重复提交的几种方法
2016/08/31 PHP
ThinkPHP 模板引擎使用详解
2017/05/07 PHP
Javascript 模式实例 观察者模式
2009/10/24 Javascript
合并table相同单元格的jquery插件分享(很精简)
2011/06/20 Javascript
jquery中event对象属性与方法小结
2013/12/18 Javascript
jQuery之ajax删除详解
2014/02/27 Javascript
JavaScript数组常用操作技巧汇总
2014/11/17 Javascript
JavaScript中的普通函数与构造函数比较
2015/04/07 Javascript
JS实现带缓冲效果打开、关闭、移动一个层的方法
2015/05/09 Javascript
JavaScript代码性能优化总结篇
2016/05/15 Javascript
JavaScript通过HTML的class来获取HTML元素的方法总结
2016/05/24 Javascript
JavaScript实现无穷滚动加载数据
2017/05/06 Javascript
史上最全JavaScript常用的简写技巧(推荐)
2017/08/17 Javascript
node.js-v6新版安装具体步骤(分享)
2017/09/06 Javascript
Vue header组件开发详解
2018/01/26 Javascript
npm全局模块卸载及默认安装目录修改方法
2018/05/15 Javascript
JavaScript实现正则去除a标签并保留内容的方法【测试可用】
2018/07/18 Javascript
[03:16]DOTA2完美大师赛小组赛精彩集锦
2017/11/22 DOTA
[01:20]DOTA2更新全新英雄 天涯墨客现已加入游戏
2018/08/25 DOTA
在Python的Django框架下使用django-tagging的教程
2015/05/30 Python
Python实现周期性抓取网页内容的方法
2015/11/04 Python
Python数据结构之单链表详解
2017/09/12 Python
python web基础之加载静态文件实例
2018/03/20 Python
PYTHON如何读取和写入EXCEL里面的数据
2019/10/28 Python
python机器学习库xgboost的使用
2020/01/20 Python
Django 解决由save方法引发的错误
2020/05/21 Python
基于python获取本地时间并转换时间戳和日期格式
2020/10/27 Python
python 基于selectors库实现文件上传与下载
2020/12/31 Python
工程总经理工作职责
2013/12/09 职场文书
老师给学生的表扬信
2014/01/17 职场文书
毕业实习单位意见
2015/06/04 职场文书
骆驼祥子读书笔记
2015/06/26 职场文书
干部培训简讯
2015/07/20 职场文书