Foxtable(狐表)用户栏目专家坐堂 → 如何实现定时指定时间自动打印


  共有4557人关注过本帖树形打印复制链接

主题:如何实现定时指定时间自动打印

帅哥哟,离线,有人找我吗?
chen_sheng
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:697 积分:6161 威望:0 精华:0 注册:2018/5/10 9:05:00
如何实现定时指定时间自动打印  发帖心情 Post By:2019/10/9 19:29:00 [显示全部帖子]

假如想把自己当天的订单通过定时任务  自动打印出来  代码如何实现  感谢指导

Dim 
Book As New XLS.Book(ProjectPath & "Attachments\订单.xls"'打开模板
Dim 
fl As String = ProjectPath & "Reports\订单.xls"
Dim 
Sheet As XLS.Sheet = Book.Sheets(0)
Sheet
(3,9).Value = "<日期 = # " & Date.Today & "#>"  '写入打印条件
Book.Build() 
'生成报表
Book.Save(fl) 

Dim 
Proc As New Process 
Proc.File = fl
Proc.Start()

 回到顶部
帅哥哟,离线,有人找我吗?
chen_sheng
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:697 积分:6161 威望:0 精华:0 注册:2018/5/10 9:05:00
  发帖心情 Post By:2019/10/10 10:45:00 [显示全部帖子]

能否就上面的实例代码指导一下,,非常感谢!

计划管理怕写的代码不合理,导致整个系统崩溃一直不敢使用,期待指导

 回到顶部
帅哥哟,离线,有人找我吗?
chen_sheng
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:697 积分:6161 威望:0 精华:0 注册:2018/5/10 9:05:00
  发帖心情 Post By:2019/10/10 12:16:00 [显示全部帖子]

我的目的是制作一个打印服务器直,接指定本服务器安装的打印机,按照代码要求时间(每天固定8:00)自动下发打印命令,自动打印出来的想法
好像去掉那些代码就是定时保存文件而已,跟我的想法还是有点偏差,再请指导一下思路和方法  谢谢


 回到顶部
帅哥哟,离线,有人找我吗?
chen_sheng
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:697 积分:6161 威望:0 精华:0 注册:2018/5/10 9:05:00
  发帖心情 Post By:2019/10/10 14:39:00 [显示全部帖子]

Dim Book As New XLS.Book(ProjectPath & "Attachments\订单.xls") '打开模板
Dim fl As String = ProjectPath & "Reports\订单.xls"
Dim Sheet As XLS.Sheet = Book.Sheets(0)
Sheet(3,9).Value = "<日期 = # " & Date.Today & "#>"  '写入打印条件
Book.Build() '生成报表
Book.Save(fl) 
Dim App As New MSExcel.Application
Dim Wb As MSExcel.WorkBook = App.WorkBooks.Open(fl)
Dim Ws As MSExcel.WorkSheet = Wb.WorkSheets(1)
Ws.PrintOut(Preview:=False)    '直接打印;http://www.foxtable.com/webhelp/topics/2121.htm
App.Quit

感谢老师 指导  刚刚报APP错 我根据实例加了行代码 

我这里还有最后一个问题  假如电脑装了几个打印机 如何指定非默认打印机打印呢   这台电脑计划仅执行打印任务,需要把资料打印到多个网络共享打印机,只是默认打印机还是解决不了我的需求,感谢!

 回到顶部
帅哥哟,离线,有人找我吗?
chen_sheng
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:697 积分:6161 威望:0 精华:0 注册:2018/5/10 9:05:00
  发帖心情 Post By:2019/10/10 15:36:00 [显示全部帖子]

static ptime As Date
If ptime <> Date.Today AndAlso Format(Date.Now, "HH:mm") >= "15:25" AndAlso Format(Date.Now, "HH:mm") <= "15:30" Then
    MyTimers("计划1").Enabled = False
    Dim Book As New XLS.Book(ProjectPath & "Attachments\订单.xls") '打开模板
    Dim fl As String = ProjectPath & "Reports\订单.xls"
    Dim Sheet As XLS.Sheet = Book.Sheets(0)
    Sheet(3,9).Value = "<日期 = # " & Date.Today & "#>"  '写入打印条件
    Book.Build() '生成报表
    Book.Save(fl)
    Dim App As New MSExcel.Application
    Dim Wb As MSExcel.WorkBook = App.WorkBooks.Open(fl)
    Dim Ws As MSExcel.WorkSheet = Wb.WorkSheets(1)
    Ws.PrintOut(Preview:=False,ActivePrinter:="RICOH Aficio MP 7001")    '直接打印;http://www.foxtable.com/webhelp/topics/2121.htm
    'Ws.PrintOut(Preview:=True,ActivePrinter:="RICOH Aficio MP 7001")
    App.Quit
    ptime = Date.Today
    MyTimers("计划1").Enabled = True
End If

帮忙看看这个代码放到计划管理没有问题吧  刚刚狐表崩溃了   打印任务成功下发
间隔:3000
[此贴子已经被作者于2019/10/10 15:38:32编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
chen_sheng
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:697 积分:6161 威望:0 精华:0 注册:2018/5/10 9:05:00
  发帖心情 Post By:2019/10/10 15:38:00 [显示全部帖子]

而且这样设置会改变电脑默认的打印机的
    'Ws.PrintOut(Preview:=True,ActivePrinter:="RICOH Aficio MP 7001")

 回到顶部
帅哥哟,离线,有人找我吗?
chen_sheng
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:697 积分:6161 威望:0 精华:0 注册:2018/5/10 9:05:00
  发帖心情 Post By:2019/10/10 15:43:00 [显示全部帖子]

你好 又测试一下  上传的是这个提醒  这次狐表没有崩溃

图片点击可在新窗口打开查看此主题相关图片如下:订单打印提示.jpg
图片点击可在新窗口打开查看

为什么会有这个提示呢   是文件没有关闭 还是咋的  代码错了

[此贴子已经被作者于2019/10/10 15:47:28编辑过]

 回到顶部
帅哥哟,离线,有人找我吗?
chen_sheng
  8楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:697 积分:6161 威望:0 精华:0 注册:2018/5/10 9:05:00
  发帖心情 Post By:2019/10/11 8:48:00 [显示全部帖子]

Dim Book As New XLS.Book(ProjectPath & "Attachments\订单.xls") '打开模板
Dim fl As String = ProjectPath & "Reports\订单.xls"
Dim Sheet As XLS.Sheet = Book.Sheets(0)
Sheet(3,9).Value = "<日期 = # " & Date.Today & "#>"  '写入打印条件
Book.Build() '生成报表
Book.Save(fl) 
Dim App As New MSExcel.Application
App.Quit
Dim Wb As MSExcel.WorkBook = App.WorkBooks.Open(fl)
Dim Ws As MSExcel.WorkSheet = Wb.WorkSheets(1)
Ws.PrintOut(Preview:=False)    '直接打印;http://www.foxtable.com/webhelp/topics/2121.htm
App.Quit

请问老师 我这样加行代码是不是可以变相解决这个问题  
或者可以通过什么方案变通解决   谢谢

 回到顶部
帅哥哟,离线,有人找我吗?
chen_sheng
  9楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:697 积分:6161 威望:0 精华:0 注册:2018/5/10 9:05:00
  发帖心情 Post By:2019/10/11 12:20:00 [显示全部帖子]

Dim Book As New XLS.Book(ProjectPath & "Attachments\订单.xls") '打开模板
Dim fl As String = ProjectPath & "Reports\订单.xls"
Dim Sheet As XLS.Sheet = Book.Sheets(0)
Sheet(3,9).Value = "<日期 = # " & Date.Today & "#>"  '写入打印条件
Book.Build() '生成报表
Book.Save(fl) 
Dim App As New MSExcel.Application
Dim ps As  System.Diagnostics.Process() = System.Diagnostics.Process.GetProcesses()
For Each p As System.Diagnostics.Process In ps
    output.show(p.processName)
    If ("Excel" = p.ProcessName)
        p.kill
    End If
Next
Dim Wb As MSExcel.WorkBook = App.WorkBooks.Open(fl)
Dim Ws As MSExcel.WorkSheet = Wb.WorkSheets(1)
Ws.PrintOut(Preview:=False)    '直接打印;http://www.foxtable.com/webhelp/topics/2121.htm
App.Quit

加这个地方合理吗

 回到顶部