百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python开发打印服务(1)

off999 2025-04-24 07:09 23 浏览 0 评论

Python开发打印服务(1)

1.需求背景

在项目开发中,我们经常会遇到打印预览、打印的需求。比如:我们在开发进销存或者其他系统应用时,经常会按照客户的需求来定制报表等。在 Web 项目中,实现打印预览及打印功能,一直以来都是借助 pdf 文件来实现,我们本次打印服务的开发也同样使用 pdf 来实现,这样,前端实现加载 pdf ,然后展现并实现打印非常容易。

2.实现思路

由于 Excel 文件的自动化操作性不是很好,所以采用 Word 文档来进行设计。

3.软件环境

软件

版本

说明

Python

3.7

服务端

python-docx


word文档操作

rpyc


远程过程调用

libreoffice

7.3

word文档到pdf文档转换

nginx

1.18

web服务

4.端口规划

服务

端口

打印服务

9999

web服务

9998

5.打印服务

打印服务提供两种:

5.1.文本打印

文本打印指的是不改变 word 模板中的非变量内容,仅仅对 word 模板中的变量进行替换。可以有表格,但表格的行数是不变化的。

5.2.表格打印

表格打印指的是除了具有文本打印的功能外,还可以对表格进行扩展,即追加行。这样的情况下,就需要对模板进行约束,具体的约束如下:

表格的最后一行用于定义与数据匹配的行定义。

5.3变量格式

格式:

#变量名#

5.3.系统变量

目前,只提供如下系统变量:

变量

说明

#sysdate#

当前日期

#systime#

当前时间

#sysdatetime#

当前日期时间

6.模板示例

word 模板示例:

7.数据格式

数据格式为 JSON 格式字符串。

文本打印的数据格式如下:

{
    field1: value1,
    field2: value2,
    field3: [val1, val2, ......],
    ......
}

字段值可以为数组,但只能是字符串数组。

表格打印的数据格式如下:

{
    field1: value1,
    field2: value2,
    field3: [val1, val2, ......],
    ......,
    datas: [object1, object2, ......]
}

datas 是必须的字段,其中为表格中的行数据。

8.调用打印服务

准备好 word 模板并存放到打印服务所在服务器的对应目录下,然后准备好数据,调用打印服务后会返回生成的 pdf 文档。打印服务提供的方法:

# 文本打印
print_text(模板文件名, json.dumps(数据变量))
# 表格打印
print_table(模板文件名, json.dumps(数据变量))

文本打印调用示例:

# coding: utf-8
import json
import rpyc


data = {'record_id': '072C47AEC56E11EC944670C94EC87656',
        'record_date': '2022-05-09', 'cb': '午餐', 'cpmc': ['炒鸡蛋', '宫保鸡丁', '姜丝炒大肠'],
        'cpmc_string': '炒鸡蛋,宫保鸡丁,姜丝炒大肠', 'lysj': '12:00', 'xswd': -3, 'jgfk': None,
        'xhsj': '2022-05-11 12:32:00', 'zrr': '刘某某',
        'restaurant_id': '053C8870BC6111EC8078525400779D9C', 'restaurant_name': '第一食堂',
        'create_time': '2022-04-26 22:34:50', 'creator_id': '86D5AF2EBC8E11EC9C9C525400779D9C', 'creator': '刘大厨',
        'org_id': '41C7A328B5B011EC9EDE70C94EC87656', 'state': 1, 'checkers': None}

c = rpyc.connect("xxx.xxx.xxx.xxx", 9999)
pdf_file = c.root.print_text('splydjb.docx', json.dumps(data))
print(pdf_file)
c.close()

生成的 pdf 文档:

表格打印服务调用示例:

# coding: utf-8
import json
import rpyc


data = {
        'record_date': '2022-05-09',
        'datas': [
            {'record_id': '072C47AEC56E11EC944670C94EC87656',
             'record_date': '2022-05-09', 'cb': '午餐', 'cpmc': ['炒鸡蛋', '宫保鸡丁', '姜丝炒大肠'],
             'cpmc_string': '炒鸡蛋,宫保鸡丁,姜丝炒大肠', 'lysj': '12:00', 'xswd': -3, 'jgfk': None,
             'xhsj': '2022-05-11 12:32:00', 'zrr': '刘某某',
             'restaurant_id': '053C8870BC6111EC8078525400779D9C', 'restaurant_name': '第一食堂',
             'create_time': '2022-04-26 22:34:50', 'creator_id': '86D5AF2EBC8E11EC9C9C525400779D9C', 'creator': '刘大厨',
             'org_id': '41C7A328B5B011EC9EDE70C94EC87656', 'state': 1, 'checkers': None},
            {'record_id': '39A33068C4F611EC962670C94EC87656',
             'record_date': '2022-05-09', 'cb': '早餐', 'cpmc': ['大米粥', '混沌', '老虎菜', '绿豆芽', '榨菜肉丝面', '素面条', '手撕包菜', '芝麻香葱饼', '素包子', '切片面包', '牛奶燕麦粥'],
             'cpmc_string': '大米粥,混沌,老虎菜,绿豆芽,榨菜肉丝面,素面条,手撕包菜,芝麻香葱饼,素包子,切片面包,牛奶燕麦粥', 'lysj': '06:00', 'xswd': -3, 'jgfk': None,
             'xhsj': '2022-04-30 08:00:00', 'zrr': '刘某某',
             'restaurant_id': '053C8870BC6111EC8078525400779D9C', 'restaurant_name': '第一食堂',
             'create_time': '2022-04-26 08:17:15', 'creator_id': '86D5AF2EBC8E11EC9C9C525400779D9C', 'creator': '刘大厨',
             'org_id': '41C7A328B5B011EC9EDE70C94EC87656', 'state': 0, 'checkers': None},
            {'record_id': 'B058C39AC4A211ECB79470C94EC87656', 'record_date': '2022-05-09', 'cb': '晚餐', 'cpmc': ['炖牛排', '烩菜', '鸡蛋蒸日本豆腐', '京酱肉丝', '鸡蛋汤', '蛤蜊蛋花汤'],
             'cpmc_string': '炖牛排,烩菜,鸡蛋蒸日本豆腐,京酱肉丝,鸡蛋汤,蛤蜊蛋花汤', 'lysj': '18:00', 'xswd': -3, 'jgfk': None,
             'xhsj': '2022-04-28 22:17:00', 'zrr': '刘某某',
             'restaurant_id': '053C8870BC6111EC8078525400779D9C', 'restaurant_name': '第一食堂',
             'create_time': '2022-04-25 22:19:16','creator_id': '86D5AF2EBC8E11EC9C9C525400779D9C', 'creator': '刘大厨',
             'org_id': '41C7A328B5B011EC9EDE70C94EC87656', 'state': 0, 'checkers': None}]}

c = rpyc.connect("xxx.xxx.xxx.xxx", 9999)
pdf_file = c.root.print_table('splydjb.docx', json.dumps(data))
print(pdf_file)
c.close()

生成的 pdf 文档:

相关推荐

python入门到脱坑经典案例—清空列表

在Python中,清空列表是一个基础但重要的操作。clear()方法是最直接的方式,但还有其他方法也可以实现相同效果。以下是详细说明:1.使用clear()方法(Python3.3+推荐)...

python中元组,列表,字典,集合删除项目方式的归纳

九三,君子终日乾乾,夕惕若,厉无咎。在使用python过程中会经常遇到这四种集合数据类型,今天就对这四种集合数据类型中删除项目的操作做个总结性的归纳。列表(List)是一种有序和可更改的集合。允许重复...

Linux 下海量文件删除方法效率对比,最慢的竟然是 rm

Linux下海量文件删除方法效率对比,本次参赛选手一共6位,分别是:rm、find、findwithdelete、rsync、Python、Perl.首先建立50万个文件$testfor...

数据结构与算法——链式存储(链表)的插入及删除,

持续分享嵌入式技术,操作系统,算法,c语言/python等,欢迎小友关注支持上篇文章我们讲述了链表的基本概念及一些查找遍历的方法,本篇我们主要将一下链表的插入删除操作,以及采用堆栈方式如何创建链表。链...

Python自动化:openpyxl写入数据,插入删除行列等基础操作

importopenpyxlwb=openpyxl.load_workbook("example1.xlsx")sh=wb['Sheet1']写入数据#...

在Linux下软件的安装与卸载(linux里的程序的安装与卸载命令)

通过apt安装/协助软件apt是AdvancedPackagingTool,是Linux下的一款安装包管理工具可以在终端中方便的安装/卸载/更新软件包命令使用格式:安装软件:sudoapt...

Python 批量卸载关联包 pip-autoremove

pip工具在安装扩展包的时候会自动安装依赖的关联包,但是卸载时只删除单个包,无法卸载关联的包。pip-autoremove就是为了解决卸载关联包的问题。安装方法通过下面的命令安装:pipinsta...

用Python在Word文档中插入和删除文本框

在当今自动化办公需求日益增长的背景下,通过编程手段动态管理Word文档中的文本框元素已成为提升工作效率的关键技术路径。文本框作为文档排版中灵活的内容容器,既能承载多模态信息(如文字、图像),又可实现独...

Python 从列表中删除值的多种实用方法详解

#Python从列表中删除值的多种实用方法详解在Python编程中,列表(List)是一种常用的数据结构,具有动态可变的特性。当我们需要从列表中删除元素时,根据不同的场景(如按值删除、按索引删除、...

Python 中的前缀删除操作全指南(python删除前导0)

1.字符串前缀删除1.1使用内置方法Python提供了几种内置方法来处理字符串前缀的删除:#1.使用removeprefix()方法(Python3.9+)text="...

每天学点Python知识:如何删除空白

在Python中,删除空白可以分为几种不同的情况,常见的是针对字符串或列表中空白字符的处理。一、删除字符串中的空白1.删除字符串两端的空白(空格、\t、\n等)使用.strip()方法:s...

Linux系统自带Python2&yum的卸载及重装

写在前面事情的起因是我昨天在测试Linux安装Python3的shell脚本时,需要卸载Python3重新安装一遍。但是通过如下命令卸载python3时,少写了个3,不小心将系统自带的python2也...

如何使用Python将多个excel文件数据快速汇总?

在数据分析和处理的过程中,Excel文件是我们经常会遇到的数据格式之一。本文将通过一个具体的示例,展示如何使用Python和Pandas库来读取、合并和处理多个Excel文件的数据,并最终生成一个包含...

【第三弹】用Python实现Excel的vlookup功能

今天继续用pandas实现Excel的vlookup功能,假设我们的2个表长成这样:我们希望把Sheet2的部门匹在Sheet1的最后一列。话不多说,先上代码:importpandasaspd...

python中pandas读取excel单列及连续多列数据

案例:想获取test.xls中C列、H列以后(当H列后列数未知时)的所有数据。importpandasaspdfile_name=r'D:\test.xls'#表格绝对...

取消回复欢迎 发表评论: