ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

如何利用VBA实现根据表格的人数生成对应的PPT的数量

[复制链接]

TA的精华主题

TA的得分主题

发表于 2016-7-29 18:57 | 显示全部楼层 |阅读模式
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
附件有两个文件,一个参训人员,一个是PPT的模板。我希望能实现通过VBA简单操作。
一:根据参训人员的人数,生成对应数量的灯片。
二:每张灯片显示的名字就是参训人员的名字。
三:灯片上的名字跟参训人员名单的名字一一对应。
我是用来打印出人员名单作为桌牌用的。
如果成功的话,应该跟附件的图片这样。按顺序生成。
捕获.JPG

Desktop.rar

498.66 KB, 下载次数: 24

TA的精华主题

TA的得分主题

发表于 2016-7-31 20:59 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
送给你一个程序,试试吧!注意要引用,程序里介绍了方法。
  1. 'VBE——引用——Microsoft excel 12.0 object library
  2. Private Sub CommandButton1_Click()
  3.    
  4.     Dim xlApp As Object
  5.     Dim xlwbk As Object        '定义工作薄对象
  6.     Dim xlsht As Object        '定义工作表对象
  7.     Dim fPath As String        '定义文件路径
  8.    
  9.     '打开对话框选择文件并获取文件路径
  10.     With Application.FileDialog(msoFileDialogFilePicker)
  11.         If .Show = False Then Exit Sub
  12.         fPath = .SelectedItems(1)
  13.     End With
  14.    
  15.     Set xlApp = CreateObject("Excel.Application")
  16.     Set xlwbk = xlApp.Workbooks.Open(fPath)
  17.     Set xlsht = xlwbk.Worksheets("入选名单")
  18.     lrow = xlsht.Range("b1").End(xlDown).Row
  19.    
  20.     For i = 1 To lrow - 1
  21.         'Set pptSlide = ActivePresentation.Slides.Add(Index:=i + 1, Layout:=ppLayoutBlank)
  22.         Set sld = ActivePresentation.Slides(i)
  23.         sld.Copy
  24.         ActiveWindow.View.Paste
  25.         
  26.         ActivePresentation.Slides(i + 1).Shapes("Text Box 2").TextFrame.TextRange.Text = xlsht.Cells(i + 2, 2).Value
  27.         ActivePresentation.Slides(i + 1).Shapes("Text Box 3").TextFrame.TextRange.Text = xlsht.Cells(i + 2, 2).Value
  28.     Next
  29.     ActivePresentation.Slides(ActivePresentation.Slides.Count).Delete
  30.     Set xlApp = Nothing
  31.     Set xlwbk = Nothing
  32.     Set xlsht = Nothing
  33. End Sub
复制代码

学会了技术,也要报答需要的人!
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-11-25 19:23 , Processed in 0.036584 second(s), 11 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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