ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
楼主: star81

[求助] WORD 打印单页自动变序号问题

[复制链接]

TA的精华主题

TA的得分主题

发表于 2016-3-21 22:11 | 显示全部楼层
本帖最后由 xwdys 于 2016-3-21 22:12 编辑

不好意思,没做程序健壮性处理,第一次使用时请在(卷号):后加4个数字,如:(卷号):0000

TA的精华主题

TA的得分主题

 楼主| 发表于 2016-3-21 23:23 | 显示全部楼层
xwdys 发表于 2016-3-21 22:11
不好意思,没做程序健壮性处理,第一次使用时请在(卷号):后加4个数字,如:(卷号):0000

哦,这样是可以打印了,能帮处理一下,可以不要每次都要改几位数的0,因为每款产品的序号编码的位数不同,如有的序号编码是两位数,有的长10位数的,谢谢您了

TA的精华主题

TA的得分主题

发表于 2016-3-22 07:48 | 显示全部楼层
star81 发表于 2016-3-21 23:23
哦,这样是可以打印了,能帮处理一下,可以不要每次都要改几位数的0,因为每款产品的序号编码的位数不同 ...

编号需要几位?少于4位时需要在编号前以0补足吗?

TA的精华主题

TA的得分主题

 楼主| 发表于 2016-3-22 13:50 | 显示全部楼层
xwdys 发表于 2016-3-22 07:48
编号需要几位?少于4位时需要在编号前以0补足吗?

您好,编号没有固定的,就是没有什么规律,有的产品编号只有2位数,有的前面有带0,有的没有,数字长短也不固定。不知道可以处理不

TA的精华主题

TA的得分主题

发表于 2016-3-22 15:20 来自手机 | 显示全部楼层
本帖最后由 xwdys 于 2016-3-25 19:09 编辑
  1. Sub FilePrint()
  2.     Dim i&, j&, lngStart&, lngCount&, lngDigit&, s$
  3.     Dim txtBox1 As Object
  4.    
  5.     lngCount = Val(InputBox("打印份数=?", , 1))
  6.     lngStart = Val(InputBox("起始卷号=?", , 1))
  7.     lngDigit = Val(InputBox("卷号几位数=?", "提示:位数少于卷号长度则以实际位数计算", 2))
  8.    
  9.     Set txtBox1 = ActiveDocument.Shapes(1).TextFrame.TextRange
  10.    
  11.     s = Replace(Mid(txtBox1, InStr(1, txtBox1, "卷号):") + 4, 10), " ", "")
  12.     If IsNumeric(s) = False Then
  13.         txtBox1 = Replace(txtBox1, "卷号):", "卷号):0")
  14.     End If
  15.    
  16.     For i = 0 To lngCount - 1
  17.             j = Len(Str(lngStart + i)) - 1
  18.             If j > lngDigit Then lngDigit = j
  19.             s = Right("0000000000" & (lngStart + i), lngDigit)
  20.             txtBox1.Find.Execute findtext:="(\(卷号\):)[ 0-9]{1,15}", replacewith:="\1" & s, MatchWildcards:=True
  21.       
  22.       '--------打印---------
  23.       ActiveDocument.PrintPreview
  24.       '    ActiveDocument.PrintOut
  25.     Next
  26. End Sub
复制代码

TA的精华主题

TA的得分主题

 楼主| 发表于 2016-3-22 17:27 | 显示全部楼层

这样是可以的,方便,但又出现1个问题,这样会把我排版的文字大小全都改变成统一的,这个我打印的就对不上标签的位置

TA的精华主题

TA的得分主题

发表于 2016-3-22 17:40 | 显示全部楼层
只在你这示例文档上做,不知道文档格式有哪些要求的?

TA的精华主题

TA的得分主题

 楼主| 发表于 2016-3-22 17:43 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
文档上要打的一些其它的数字或是字母的信息我有排好字号大小,还有字体,打印的时候要保留我文档上其它字体及字号大小不变

TA的精华主题

TA的得分主题

 楼主| 发表于 2016-3-22 17:44 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
xwdys 发表于 2016-3-22 17:40
只在你这示例文档上做,不知道文档格式有哪些要求的?


文档上要打的一些其它的数字或是字母的信息我有排好字号大小,还有字体,打印的时候要保留我文档上其它字体及字号大小不变

TA的精华主题

TA的得分主题

发表于 2016-3-22 17:45 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
建议编号放在一个独立的文本框内,这样不会影响其它格式
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2025-1-14 20:01 , Processed in 0.034528 second(s), 8 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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