ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] VBA打印设置问题

[复制链接]

TA的精华主题

TA的得分主题

发表于 2018-1-23 19:06 | 显示全部楼层 |阅读模式
Sub test()
        With Worksheets("基础知识").PageSetup
            .Zoom = False
            .FitToPagesWide = 1
            .FitToPagesTall = 1
            Worksheets("基础知识").PrintOut
        End With
End Sub
这段代码的意思不是将”基础知识“sheet页缩放到一张A4纸中打印吗?为什么打印出来的还是因为文字过长而打印在两页A4纸中,需要怎样修改代码?求解答,万分感谢!

2.9 逻辑运算符(and与or综合应用).rar

59.39 KB, 下载次数: 7

TA的精华主题

TA的得分主题

发表于 2018-1-23 21:31 | 显示全部楼层
文件选项里检查下打印纸张是否为A4,或者增加一下代码:
.PaperSize = xlPaperA4

TA的精华主题

TA的得分主题

发表于 2018-1-23 22:42 | 显示全部楼层
Sub 方法一把打印区域缩小一定的比例()
    With ActiveSheet.PageSetup
        .Zoom = 80                        '缩小为80%打印
        Range("b1:i37").PrintPreview      '打印预览
    End With
End Sub

Sub 方法二把打印区域缩放在一页范围内()
    With ActiveSheet.PageSetup
        .Zoom = False        '不设置页面缩放固定比例
        .FitToPagesWide = 1  '页面缩放,调整为一页高
        .FitToPagesTall = 1  '页面缩放,调整为一页宽
        Range("b1:i37").PrintPreview   '打印预览
    End With
End Sub

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-1-24 19:13 | 显示全部楼层
hzruziniu 发表于 2018-1-23 22:42
Sub 方法一把打印区域缩小一定的比例()
    With ActiveSheet.PageSetup
        .Zoom = 80             ...

首先先谢谢,我写了一串代码,准备循环文件夹下的所有工作簿打印,所以单元格区域打印不太靠谱,因为每个工作簿的区域不相同。所以想问问有没有什么代码可以循环设置。不要一句话截成两页打印。

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-1-24 19:16 | 显示全部楼层
看见星光 发表于 2018-1-23 21:31
文件选项里检查下打印纸张是否为A4,或者增加一下代码:
.PaperSize = xlPaperA4

首先先谢谢,我写了一串代码,准备循环文件夹下的所有工作簿打印,设成A4并不起作用。像附件那样会将一句话截成两页打印

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-1-24 20:00 | 显示全部楼层
看见星光 发表于 2018-1-23 21:31
文件选项里检查下打印纸张是否为A4,或者增加一下代码:
.PaperSize = xlPaperA4

重新试了一下自己的那个代码,其他工作簿都可以实现,就附件的工作簿不能实现.....。还是很感谢

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-1-24 20:01 | 显示全部楼层
hzruziniu 发表于 2018-1-23 22:42
Sub 方法一把打印区域缩小一定的比例()
    With ActiveSheet.PageSetup
        .Zoom = 80             ...

重新试了一下自己的那个代码,其他工作簿都可以实现,就附件的工作簿不能实现.....。还是很感谢

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-1-24 20:02 | 显示全部楼层
hzruziniu 发表于 2018-1-23 22:42
Sub 方法一把打印区域缩小一定的比例()
    With ActiveSheet.PageSetup
        .Zoom = 80             ...

重新试了一下自己的那个代码,其他工作簿都可以实现,就附件的工作簿不能实现.....。还是很感谢

TA的精华主题

TA的得分主题

发表于 2018-1-25 11:24 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
别烦我123456 发表于 2018-1-24 20:02
重新试了一下自己的那个代码,其他工作簿都可以实现,就附件的工作簿不能实现.....。还是很感谢

你试试下面代码

  1. Sub 多表循环缩放为一页打印()
  2.     Dim sht As Worksheet
  3.     For Each sht In Sheets
  4.         If sht.Name <> "打印表" Then
  5.             sht.Select
  6.             With ActiveSheet.PageSetup
  7.                 .Zoom = False        '不设置页面缩放固定比例
  8.                 .FitToPagesWide = 1  '页面缩放,调整为一页高
  9.                 .FitToPagesTall = 1  '页面缩放,调整为一页宽
  10.                 ActiveSheet.PrintPreview   '打印预览
  11.             End With
  12.         End If
  13.     Next
  14. End Sub
复制代码

TA的精华主题

TA的得分主题

发表于 2018-1-25 11:33 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
多表缩放一页打印.rar (9.27 KB, 下载次数: 20)

请看附件,因为是打印其他表,所以先应激活该表。
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

关闭

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

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

GMT+8, 2024-4-25 06:57 , Processed in 0.037636 second(s), 9 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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