ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
300集Office 2010微视频教程 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 12643|回复: 26

[求助] 实现按顺序连续打印

[复制链接]

TA的精华主题

TA的得分主题

发表于 2014-8-21 16:14 | 显示全部楼层 |阅读模式
论坛的各位老师:大家好!
        如下图所示,在工作中,制作好一个模板后,想根据选择实现连续打印!恳求各位老师帮忙。
连续打印.jpg

单体砖图成型卡片.zip (44.41 KB, 下载次数: 339)

TA的精华主题

TA的得分主题

发表于 2014-8-21 19:31 | 显示全部楼层
  1. Sub 打印()
  2. Dim fw$, fs&
  3. fs = Sheet1.[m2]
  4. If fs < 1 Then Exit Sub
  5. fw = Replace("q" & Sheet1.[m1], "-", ":q")
  6. For Each cel In Sheet2.Range(fw)
  7.     If cel.Row >= 5 Then
  8.         phzx = cel.Value
  9.         If phzx <> "" Then
  10.             Sheet1.[j1] = phzx
  11.             Sheet1.PrintOut copies:=fs
  12.         End If
  13.     End If
  14. Next
  15. End Sub
复制代码

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2014-8-21 19:36 | 显示全部楼层
单体砖图成型卡片.zip (47.1 KB, 下载次数: 451)

点评

感谢帮助!谢谢。  发表于 2014-8-21 19:58

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-8-22 15:15 | 显示全部楼层
cbtaja 发表于 2014-8-21 19:36

老师好!这个程序是不是有点不稳定呢?
1、我选择6-7,打印出来的是确实第5行和第7行。
2、重新打印,内容是第6行和第7行,但是图却都是第7行的图,
3、还有打印7-9,打印的图片也有出错的情况,第7行的图和第8行的图原本不一样,打印出来的都是第7行的图!
恳请老师在看看这个程序是否有不稳定的因素存在?

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-8-22 15:22 | 显示全部楼层
cbtaja 发表于 2014-8-21 19:36

输入单个数字打印,目前还没有发现问题。就是连续打印的时候会有时候出错,有时候又正常。

TA的精华主题

TA的得分主题

发表于 2014-8-23 10:08 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
kuangben8 发表于 2014-8-22 15:15
老师好!这个程序是不是有点不稳定呢?
1、我选择6-7,打印出来的是确实第5行和第7行。
2、重新打印,内 ...

这种情况,只需在执行打印命令的语句之前加上一句即可解决:
DoEvents

对原有代码一并优化完善如下:
  1. Sub 打印()
  2. Dim fw$, fs&, endrow&, r&, phzx$
  3. fs = Sheet1.[m2]
  4. If fs < 1 Then Exit Sub
  5. endrow = Sheet2.[b65536].End(3).Row
  6. fw = Replace("q" & Sheet1.[m1], "-", ":q")
  7. For Each cel In Sheet2.Range(fw)
  8.     r = cel.Row
  9.     If r >= 5 And r <= endrow Then
  10.         phzx = cel.Value
  11.         Sheet1.[j1] = phzx
  12.         DoEvents
  13.         Sheet1.PrintOut copies:=fs
  14.     End If
  15. Next
  16. MsgBox "完成!"
  17. End Sub
复制代码

TA的精华主题

TA的得分主题

 楼主| 发表于 2014-8-23 10:53 | 显示全部楼层
cbtaja 发表于 2014-8-23 10:08
这种情况,只需在执行打印命令的语句之前加上一句即可解决:
DoEvents

感谢老师的帮助!谢谢。

TA的精华主题

TA的得分主题

 楼主| 发表于 2015-3-25 16:17 | 显示全部楼层
cbtaja 发表于 2014-8-23 10:08
这种情况,只需在执行打印命令的语句之前加上一句即可解决:
DoEvents

大侠好,我不清楚我的要求是否麻烦,如果可以,想请您帮我一下:
http://club.excelhome.net/forum. ... 194&pid=8138592
如果不行,也很感谢您观看我的问题。

TA的精华主题

TA的得分主题

 楼主| 发表于 2016-5-10 16:11 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
cbtaja 发表于 2014-8-23 10:08
这种情况,只需在执行打印命令的语句之前加上一句即可解决:
DoEvents

老师好,我现在想将这个连续打印程序输出为PDF格式文件,按照打印顺序保存在一个PDF文档里。请教老师该如何修改您的代码?

TA的精华主题

TA的得分主题

发表于 2016-5-11 17:00 | 显示全部楼层
不用改代码,安装一个著名的虚拟打印机FinePrint(有中文版v8.31的,单机版注册码HZUC-MGGY-5479),设为默认打印机,就可解决问题。
打印时,它将拦截所有的打印内容,最后可由它统一转给其它物理打印机或PDF虚拟打印机。如果转的是PDF打印机,自然就把这些内容一次性转为了一个PDF文档。
FinePrint还有其它功能,当然,最主要的是它相当于给任何提供打印功能的软件增加了“打印预览”的功能,而且,对于其中的页面,可以随意的删除。比如想打印第1-3、6,8-10页,可以先用FinePrint直接打印第1-10页,然后在FinePrint中,把第4、5、7页删除,再转发给其它物理打印机。所以,可以利用它删除打印预览时发现的多余的空白页。此外,也可以利用它在需要的位置插入空白页,添加页眉页脚、水印、以及为没有双面打印功能的打印机提供双面打印功能等。
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

关闭

最新热点上一条 /1 下一条

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-4-20 16:21 , Processed in 0.048426 second(s), 11 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表