- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在假脱机期间在本地机器上最初请求打印作业时,我已经成功地触发了回调。但是,是否有 win32print
或类似的东西可以让我处理将打印作业传输到打印服务器或 USB 打印机的事件?
################################################################################
# Imports ######################################################################
################################################################################
from os.path import *
from printer import *
from watcher import *
from statvar import *
################################################################################
# Event Callback ###############################################################
################################################################################
def callback(code, event):
num = splitext(event)[0]
ext = splitext(event)[1]
if code == 1 and ext == '.SPL':
main(num.lstrip('0'))
################################################################################
# wx Event Handler #############################################################
################################################################################
def handling(*args):
wx.CallAfter(callback, *args)
################################################################################
# Create Listener ##############################################################
################################################################################
# listens to the spool directory for files
watch = Watcher(SPOOL_DIRECTORY, handling)
# set the appropriate flags for a listener
watch.flags = FILE_NOTIFY_CHANGE_FILE_NAME
################################################################################
# Start Listener ###############################################################
################################################################################
watch.start()
################################################################################
# Start wx App #################################################################
################################################################################
app = wx.App()
wx.Frame(None)
app.MainLoop()
################################################################################
################################################################################
################################################################################
最佳答案
这是一个在我的电脑 (Windows 8) 上可行的想法。它不是完全成熟的代码,但它可能会让你继续。您需要使用函数 FindFirstPrinterChangeNotification
和 FindNextPrinterChangeNotification
这些包含在客户端的 winspool.drv
中(令人恼火的是,您会发现它们被记录在 spoolSS.dll
中,但这是服务器端 - this diagram 可以澄清)。
可从MSDN here 获得可以监听的事件列表(重要的是,它们的标志设置) .最初我以为您想要 PRINTER_CHANGE_ADD_JOB
(0x00000100
),但我认为您实际上可能想要 PRINTER_CHANGE_WRITE_JOB
(0x00000800
)。这不会在作业开始假脱机时立即触发,但不幸的是,在您将一个文档发送到网络打印机的示例中,它似乎确实被触发了多次。
不幸的是,这些 API 没有在 win32print
库中公开。我认为,因此您必须深入研究 ctypes
。在这里我没有注册回调,而是监听通知,当触发时我调用该函数并在无限循环中再次开始监听。该过程在收听时停滞。如果您需要传统的回调功能,您可以在它自己的线程中运行这个脚本,或者这个答案可能不适合您的需要。
注意 - 这只是监听正在请求的打印作业,然后调用一个函数。如果你想提取有关被触发的作业的信息,代码将变得可怕。进一步注意 - 它会触发开始并随后取消的打印作业,但我认为这很好。
from ctypes import *
from ctypes.wintypes import HANDLE, LPSTR
def add_job_callback():
print('A job has just been sent to the printer this script is monitoring')
spl = windll.LoadLibrary('winspool.drv')
printer_name = 'KONICA MINOLTA PS Color Laser Class Driver'
# Put the name of your printer here - can be networked or any installed on your computer. Alternatively, set it to None to use the local printer server
#printer_name = None
hPrinter = HANDLE()
if printer_name:
spl.OpenPrinterA(c_char_p(printer_name), byref(hPrinter),None)
else:
spl.OpenPrinterA(None, byref(hPrinter),None)
print(hPrinter)
hjob = spl.FindFirstPrinterChangeNotification(hPrinter,0x00000100,0, None)
# 0x00000100 is a flags setting to set watch for only PRINTER_CHANGE_ADD_JOB
while True:
windll.kernel32.WaitForSingleObject(hjob,-1)
#When this function returns, the change that you're monitoring for has been observed, trigger the function
add_job_callback()
spl.FindNextPrinterChangeNotification(hjob, None, None, None)
请注意,Python 2.7 和 Python 3 之间存在一些细微差异 - 例如从字符串初始化 c_char_p
ctype
。我在这里展示了我所能提供的最简单的版本——它适用于 2.7。
后记
我完成了所有繁重的工作,然后找到了 this answer ,那是重复的东西。它有更好的代码来处理 unicode 打印机名称等,但只查看默认的本地打印服务器。
关于python - 收到打印作业 Python,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34519642/
我有一个静态类。 static class AppDirectory { public static string PACSTEMP = Path.Combine(Path.GetTempPa
我已经设置了一个启用了推送通知的 iOS 应用。 我可以将消息推送到应用程序,例如角标(Badge)计数工作并相应更新。 但我从未在锁屏或其他地方看到标准的推送通知弹出窗口,但手机会振动,因此消息会通
我们有一个带有 Web 应用程序和一堆 Windows 服务的系统,它们在做一些后台工作。 每当我们需要对系统进行更实质性的更改时,我们最终不得不发出 IIS 重置,然后手动重新启动所有相关的 Win
我有以下几行 John SMith: A Pedro Smith: B Jonathan B: A John B: B Luis Diaz: A Scarlet Diaz: B 我需要获得所有获得
我正在编写一个 Java 客户端(在 weblogic 10.3 上)来调用一个安全的网络服务。我已获得安装在 cacerts、DemoIdentity.jks 和 DemoTrust,jks 中的客
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎偏离主题,因为它缺乏足够的信息来诊断问题。 更详细地描述您的问题或 include a mini
我正在尝试调用void方法addToList,该方法将通过用户传递给它的两个字符串除外。我检查了dataSource类,以确保它确实接受了那些作为参数。问题是我在该方法调用上始终收到标识符>预期错误,
我的任务:使用scanner方法从一行数据中提取字符串、 float 和整数。 数据格式为: Random String, 240.5 51603 Another String, 41.6 59087
这个问题已经有答案了: What causes a java.lang.ArrayIndexOutOfBoundsException and how do I prevent it? (25 个回答)
首先我实例化一个游戏状态 class GameState extends state{ ArrayList levels; int currentLevelID; public GameState()
已关闭。这个问题是 not reproducible or was caused by typos 。目前不接受答案。 这个问题是由拼写错误或无法再重现的问题引起的。虽然类似的问题可能是 on-top
我有一个实现为单例的 Controller 对象,它有一个可以随时驱逐对象的缓存。当一个对象即将被删除时,我想通知任何使用此 Controller 的类,以便它们能够做出适当的响应。我对这种行为的第一
因此,我尝试跨集群发送消息,该消息将包含一个 User 对象,该对象是一个可序列化类。 当我发送 String 或 int 时,它工作正常,消息发送没有问题,并且集群上的所有 channel 都收到它
我试图创建的程序是一个基本游戏,用户输入网格大小,选择 block 接收增加分数的奖品、从分数中夺走分数的强盗或结束游戏的炸弹。我收到堆栈流错误,但我不明白为什么? 抱歉,代码量很大,我只是无法找到问
使用此代码我会得到什么ConcurrentModificationException?我有一个同步(监听器)锁。 private void notifyListeners(MediumRenditio
我想在捕获 DeadlineExceededError 后正确退出。我还剩下多少钱来清理? 例如, try: do_some_work() except DeadlineExceededError
我有 2 个 Intranet 站点: http://intranetv1/ http://intranetv2/ v1基于.NET 1.1,v2基于.NET 3.5 在 v1 上,我创建了一个网页,
我有一个在 Linux 3.12 上运行的 C 程序。该程序产生几个子进程。其中一个进程会生成一个线程,该线程运行一段时间然后终止。当该子进程运行时,它会执行 epoll_wait()。 epoll_
我能够将 APNS 集成到我的应用程序中。现在我想在用户点击它或用户在使用应用程序时收到通知时处理通知。我使用下面的代码在收到通知时显示警报对话框: func application(applicat
当我试图在浏览器上运行这段代码时,出现了以下错误。"错误响应错误代码:501消息:不支持的方法(“POST”)。错误码解释:501-服务器不支持该操作。" 浏览器控制台出现以下错误: "1.加载资源失
我是一名优秀的程序员,十分优秀!