【python】云打印实现

简介: 【python】云打印实现

这两天为了实现云打印功能找了很多相关的文章

记录一下这一篇,python云打印实现-朝花夕拾,代码通过监听文件夹有无产生新文件来判断是否执行,我尝试运行了下没问题,于是打算转载一下

程序运行结果

由于对方的代码和我实现的有点出入但都是先下载,后打印,只不过我的实通过mqtt服务器罢了,于是通过一步一步解析,我发现他这里有几个需要注意的,给大家和自己才个坑

1、settings.json 配置打印机和监控文件夹

2、不支持图片和pdf打印,有点难弄,后面处理了我会附上

3、不支持彩彩印规格这些

4、打印机用默认的即可,配置没多大作用,因为最后参数没有传过去

我改良后的

import time
import win32api
import win32print
from watchdog.observers import Observer
from watchdog.events import *
import json
import sys
import traceback
import os
def printer_loading(filename, printer):
    win32api.ShellExecute(
        0,
        "print",
        filename,
        '/d:"%s"' % win32print.GetDefaultPrinter(),
        ".",
        0
    )
'''
def printer_pic(pic_path, printer_name):
    # 物理宽度、高度
    PHYSICALWIDTH = 110
    PHYSICALHEIGHT = 111
    # 物理偏移位置
    PHYSICALOFFSETX = 112
    PHYSICALOFFSETY = 113
    printer_name = win32print.GetDefaultPrinter()
    hDC = win32ui.CreateDC()
    hDC.CreatePrinterDC(printer_name)
    printer_size = hDC.GetDeviceCaps(PHYSICALWIDTH), hDC.GetDeviceCaps(PHYSICALHEIGHT)
    # printer_margins = hDC.GetDeviceCaps (PHYSICALOFFSETX), hDC.GetDeviceCaps (PHYSICALOFFSETY)
    # 打开图片
    # #通过每个像素使它尽可能大
    # #页面不失真。
    bmp = Image.open(file_name)
    ratios = [1.0 * 1754 / bmp.size[0], 1.0 * 1240 / bmp.size[1]]
    scale = min(ratios)
    # #开始打印作业,并将位图绘制到
    # #按比例缩放打印机设备。
    hDC.StartDoc(file_name)
    hDC.StartPage()
    dib = ImageWin.Dib(bmp)
    scaled_width, scaled_height = [int(scale * i) for i in bmp.size]
    print(scaled_width, scaled_height)
    x1 = int((printer_size[0] - scaled_width) / 2)
    y1 = int((printer_size[1] - scaled_height) / 2)
    # 横向位置坐标
    x1 = 1580
    # 竖向位置坐标
    y1 = 30
    # 4倍为自适应图片实际尺寸打印
    x2 = x1 + bmp.size[0] * 4
    y2 = y1 + bmp.size[1] * 4
    dib.draw(hDC.GetHandleOutput(), (x1, y1, x2, y2))
    hDC.EndPage()
    hDC.EndDoc()
    hDC.DeleteDC()
'''
class FileEventHandler(FileSystemEventHandler):
    def __init__(self,printer):
        FileSystemEventHandler.__init__(self)
        self.printer = printer
    def on_created(self, event):
        print(event.is_directory)
        if event.is_directory:
            print("directory created:{0}".format(event.src_path))
        else:
            print("file created:{0}".format(event.src_path))
            if event.src_path.endswith("docx") or event.src_path.endswith("doc") or event.src_path.endswith("xlsx") or event.src_path.endswith("jpg") or event.src_path.endswith("pdf") or event.src_path.endswith("xls") or event.src_path.endswith("txt") or event.src_path.endswith("img"):
                if "~" not in event.src_path:
                    print(f"打印路径{event.src_path}")
                    print(f"打印机名字{self.printer}")
                    printer_loading(event.src_path, self.printer)
# import time
# win32api.ShellExecute(0, 'open', 'C:\\Program Files (x86)\\Allway Sync\\Bin\\syncappw.exe', '','',1)
if __name__ == "__main__":
    try:
        observers = []
        print("当前检测到的打印机:")
        maxL = 2
        Num = 2
        for i in range(1, 10):
            # print(i)
            r = win32print.EnumPrinters(i)
            l = len(r)
            if l > maxL:
                maxL = l
                Num = i
        for i, p in enumerate(list(win32print.EnumPrinters(Num))):
            print(f"\t{i}:{p[1]}\n")
        # f = open('.ttings.txt', 'r', encoding="utf-8")
        settings = {}
        # print("当前配置:")
        # for line in f.readlines():
        #     k, v = line.split(",")
        #     settings[k.strip()] = v.strip()
        #     print(f"\t{k}:{v}")
        print("当前配置:")
        with open("./settings.json", 'rb') as load_f:
            ds = json.load(load_f)
            for d in ds:
                settings[d['url'].strip()] = d["printer"].strip()
                print(f"\t{d}")
        pass
        for path, printer in settings.items():
            observer = Observer()
            print("打印机名"+printer)
            event_handler = FileEventHandler(printer)
            observer.schedule(event_handler, path, True)
            observer.start()
            observers.append(observer)
        try:
            while True:
                time.sleep(1)
        except KeyboardInterrupt:
            for observer in observers:
                observer.stop()
        for observer in observers:
            observer.join()
    except Exception as e:
        print(e)
        traceback.print_exc()
        input()

完整代码在这里:xxxxx


我顺藤摸瓜发现我们启动的方法不一样,我的是通过

w = DispatchEx('kwps.Application')
 w.Visible = 0  # 不打开软件
 w.DisplayAlerts = 0  # 不报错
doc = w.Documents.Open(f)

而他的核心代码是通过

# 打印输出
                    def printer_loading(filename, printer):
                        win32api.ShellExecute(
                            0,
                            "print",
                            filename,
                            '/d:"%s"' % win32print.GetDefaultPrinter(),
                            ".",
                            0
                        )
                    # 打印

暂时只知道第一个代码需要安装wps,第二个未测试

client_mqtt版(需要配合mqtt数据使用,不建议下载,自己用,需要安装wps-珠海zf版本)

client_mqtt_plus(需要配合mqtt数据使用,不建议下载,自己用,需要安装wps-珠海zf版本)

朝花夕拾-改良版(可以下载)

相关实践学习
快速体验阿里云云消息队列RocketMQ版
本实验将带您快速体验使用云消息队列RocketMQ版Serverless系列实例进行获取接入点、创建Topic、创建订阅组、收发消息、查看消息轨迹和仪表盘。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
相关文章
|
存储 网络协议 安全
部署打印服务(一)
部署打印服务(一)
910 0
element中使用走马灯效果el-carousel点击按钮切换第几页demo效果示例(整理)
element中使用走马灯效果el-carousel点击按钮切换第几页demo效果示例(整理)
|
3月前
|
编解码 Ubuntu Linux
ubuntu系统安装指南:免费且适合老旧电脑,4GB内存也能流畅运行!
点击启动台,找到并点击设置。在设置中,选择语言和区域,再点击管理语言。安装所需的语言包,输入密码进行确认。等待大约2分钟,语言包安装完成后,点击安装语言,选择中文选项。这里有简体和繁体两种选择,根据个人需求进行选择。再次等待2分钟,安装完成后,点击这里,选择中文并应用。然后,将出现的中文拖动到最上面,应用更改并退出设置。最后,重启虚拟机,再次进入系统时,你会发现界面已经变成了中文,而且系统依然保持流畅。Ubuntu系统不仅外观漂亮、干净,而且性能稳定、安全可靠。如果你的电脑内存只有4GB,或者你对Windows系统感到厌倦,那么Ubuntu绝对是一个值得尝试的选择。它不仅办公打印一应俱全,还拥
|
缓存 关系型数据库 PostgreSQL
PostgreSQL自增ID的初始化语句
【5月更文挑战第10天】PostgreSQL自增ID的初始化语句
633 2
|
存储 自然语言处理 API
基于 Python 的地址解析:自动识别姓名、电话、地址、详细地址与省市区
基于 Python 的地址解析:自动识别姓名、电话、地址、详细地址与省市区
2151 1
|
分布式计算 关系型数据库 MySQL
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型 图像处理 光通信 分布式计算 算法语言 信息技术 计算机应用
253 8
|
开发框架 移动开发 前端开发
除了 HMR 插件,还有哪些技术可以实现热更新?
【10月更文挑战第23天】不同的热更新技术都有其特点和适用场景。开发者需要根据项目的具体需求和技术架构,选择合适的热更新技术来提高开发效率和用户体验。同时,随着技术的不断发展,热更新技术也在不断创新和完善,未来可能会出现更多更先进的热更新技术和方法。
|
Web App开发 JavaScript 前端开发
Node.js与Go语言的对比?
【8月更文挑战第4天】Node.js与Go语言的对比?
1061 3
|
资源调度 JavaScript
vue项目:集成富文本编辑器 - 百度ueditor(vue-ueditor-wrap)
vue项目:集成富文本编辑器 - 百度ueditor(vue-ueditor-wrap)
1519 0
|
开发框架 JavaScript 前端开发
分享7个.NET开源、功能强大的快速开发框架
分享7个.NET开源、功能强大的快速开发框架
823 1