Python 实现自动完成A4标签排版打印功能
老婆大人让俺帮她通过Excel生成百人的准考证,她们学校打算来一次高考模拟。由于高考改革,每个学生的考试科目不一样,需要自动生成一下。
我一个程序员平时很少用到Excel,自己也不打算深入研究这个软件。如何解决她的需求呢?我直接想到了python,无所不能的python肯定可以搞定这个小case。
解决思路
数据处理:这个很简单的
生成可打印的文件
这个有些难度,我首先想到生成word。而且python也有word包来解决,不过后来想了一下,这个方案有问题。word结构不开源,格式和样式处理起来应该有问题。另外word在国外不普遍,遇到问题解决方案肯定不多。而PDF却不同,PDF在国外应用广使用人多,肯定好解决。
寻找方案
通过python生成pdf的方案确定后,果然通过Google找到了pylabels这个库。
如何解决
第一步安装库
pipinstallpylabels
第二步执行下面的代码
importlabels fromreportlab.graphicsimportshapes specs=labels.Specification(210,297,2,8,90,25,corner_radius=2) defdraw_label(label,width,height,obj): label.add(shapes.String(2,2,str(obj),fontName="Helvetica",fontSize=40)) #Createthesheet. sheet=labels.Sheet(specs,draw_label,border=True) #Addacoupleoflabels. sheet.add_label("Hello") sheet.add_label("World") #Wecanalsoaddeachitemfromaniterable. sheet.add_labels(range(3,22)) sheet.add_label("Oversizedlabelhere") #Savethefileandwearedone. sheet.save('basic.pdf') print("{0:d}label(s)outputon{1:d}page(s).".format(sheet.label_count,sheet.page_count))
数据处理部分我就不分享了,就是简单的读取csv文件。
以上这篇Python实现自动完成A4标签排版打印功能就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。