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逐行读取文件内容的三种方法
Jan 20 Python
python实现马耳可夫链算法实例分析
May 20 Python
通过Python使用saltstack生成服务器资产清单
Mar 01 Python
Python教程之全局变量用法
Jun 27 Python
快速入门python学习笔记
Dec 06 Python
python 实现判断ip连通性的方法总结
Apr 22 Python
在python中实现同行输入/接收多个数据的示例
Jul 20 Python
浅析python标准库中的glob
Mar 13 Python
python用tkinter实现一个gui的翻译工具
Oct 26 Python
Jupyter notebook命令和编辑模式常用快捷键汇总
Nov 17 Python
python实现会员管理系统
Mar 18 Python
什么是Python装饰器?如何定义和使用?
Apr 11 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初学者最感迷茫的问题小结
2010/03/27 PHP
php实现面包屑导航例子分享
2015/12/19 PHP
YII分模块加载路由的实现方法
2018/10/01 PHP
Extjs4 GridPanel的主要配置参数详细介绍
2013/04/18 Javascript
jQuery制作仿Mac Lion OS滚动条效果
2015/02/10 Javascript
javascript作用域问题实例分析
2015/07/13 Javascript
快速入门Vue
2016/12/19 Javascript
JS实现焦点图轮播效果的方法详解
2016/12/19 Javascript
vue Render中slots的使用的实例代码
2017/07/19 Javascript
koa router 多文件引入的方法示例
2019/05/22 Javascript
[44:22]完美世界DOTA2联赛循环赛 FTD vs PXG BO2第一场 11.01
2020/11/02 DOTA
Python抓取Discuz!用户名脚本代码
2013/12/30 Python
Python实现根据指定端口探测服务器/模块部署的方法
2014/08/25 Python
Python中的pprint折腾记
2015/01/21 Python
Python实现的桶排序算法示例
2017/11/29 Python
python获取网页中所有图片并筛选指定分辨率的方法
2018/03/31 Python
python爬虫的数据库连接问题【推荐】
2018/06/25 Python
pyqt5实现按钮添加背景图片以及背景图片的切换方法
2019/06/13 Python
用django-allauth实现第三方登录的示例代码
2019/06/24 Python
python统计字符的个数代码实例
2020/02/07 Python
超级实用的8个Python列表技巧
2020/08/24 Python
websocket+sockjs+stompjs详解及实例代码
2018/11/30 HTML / CSS
HTML5 Canvas中绘制矩形实例
2015/01/01 HTML / CSS
阿迪达斯奥地利官方商城:adidas.at
2016/10/16 全球购物
Gibson London官网:以地道的英国男装而著称
2019/12/06 全球购物
什么是Rollback Segment
2013/04/22 面试题
了解AppleShare protocol(AppleShare协议)吗
2015/08/28 面试题
跟单文员的岗位职责
2013/11/14 职场文书
工程部经理岗位职责
2013/12/08 职场文书
医院办公室主任职责
2013/12/29 职场文书
汽车销售顾问求职自荐信
2014/01/01 职场文书
幼儿园数学教学反思
2014/02/02 职场文书
教师工作自我鉴定范文
2014/09/14 职场文书
2014年客服工作总结范文
2014/11/13 职场文书
2014年采购部工作总结
2014/11/20 职场文书
python函数的两种嵌套方法使用
2022/04/02 Python