Sub CreateTables()
Dim Wb As Workbook
Dim OpenWb As Workbook
Dim Sht As Worksheet
Dim Rng As Range
Dim Arr As Variant
Dim i As Long
Const HEAD_ROW As Long = 2
Dim EndRow As Long '模板文件名和路径
Const ModelName As String = "社+名.xlsx"
Dim ModelPath As String
'生成文件名和路径
Dim NewName As String
Dim NewPath As String Set Wb = Application.ThisWorkbook
Set Sht = Wb.Worksheets("明细表") ModelPath = Wb.Path & "\模板\" & ModelName '社+名的完整路径 With Sht
EndRow = .Cells(.Cells.Rows.Count, "A").End(xlUp).Row
'内置方法,返回A列最后一个非空单元格行号 Set Rng = .Range(.Cells(HEAD_ROW + 1, "A"), .Cells(EndRow, "I"))
'引用区域,左上角单元格,右下角单元格,这样就获取数据区域了 自己领悟一下就知道了 Arr = Rng.Value
'存在一个数组里面,这样速度好很多
'和单元格区域是一样的。只是它只有数据,没有框框颜色字体什么的,所以用起来很快 Set OpenWb = Application.Workbooks.Open(ModelPath)
'打开模板文件 For i = LBound(Arr) To UBound(Arr) '从第一行到最后一行,逐行循环
'arr相当于是一个有行列结构的数组,和单元格区域是一样的。Lbound可以取到开始行,Ubound可以取到结束行 '开始构建新文件名
NewName = Arr(i, 9) & "-" & Arr(i, 2) & ".xlsx"
'i是可变的,9就是第I列 经办行,2就是第B列的客户名称,新文件名就弄好了
NewPath = Wb.Path & "\生成\" & NewName
'新文件名的完整路径 就构造好了 '开始填表
'这里就做两个示范,剩下的你自己填就知道了
'第一个sheet
OpenWb.Worksheets("(一)档案封皮").Range("B13").Value = Arr(i, 2) '借款人
OpenWb.Worksheets("(一)档案封皮").Range("A23").Value = Arr(i, 9) '经办行 OpenWb.Worksheets("(二)债务主体认定书").Range("B4").Value = Arr(i, 2) '经办行
OpenWb.Worksheets("(二)债务主体认定书").Range("B5").Value = "'" & Arr(i, 1) '贷款号
'注意注意注意 长数字 前面一定要加上 "'" & ,这样防止后面三位数字变成 000 '************剩下自己弄 OpenWb.SaveCopyAs NewPath '填完就另存副本 Next i OpenWb.Close False '关掉模板
End With '释放对象,告诉内存,这些东东我不要了,不然一直占着内存
Set Wb = Nothing
Set OpenWb = Nothing
Set Sht = Nothing
Set Rng = Nothing
Erase Arr '擦除数组 End Sub

  

20170727xlVBA根据数据表和模板工作簿生成个人明细表工作簿的更多相关文章

  1. 20170731xlVba根据数据表和模板表生成新表

    Public Sub SplitData() Dim Wb As Workbook Dim Sht As Worksheet Dim NewSht As Worksheet Dim arr As Va ...

  2. MySQL数据表更新模板

    -- ---------------------------- -- 新增表 -- ---------------------------- CREATE TABLE `biz_circle_lead ...

  3. SqlProfilter监控指定数据库数据表——监控linq组合查询生成的sql

    1.例子 实际测试环境中往往很多测试都在调用数据库,那么如何使用SqlProfilter监控筛选到自己想要监看的数据库对应的表有关linq生成的sql时候就需要做如下设置了 ........... u ...

  4. 帝国cms数据表详细说明

    表 名 解释 phome_ecms_infoclass_news 新闻采集规则记录表 phome_ecms_infotmp_news 采集临时表 phome_ecms_news 新闻主数据记录表 ph ...

  5. 帝国cms数据表中文说明

    本文介绍下,帝国cms中各数据表的用途,有需要的朋友,参考下吧. 帝国cms各数据表及用途说明. phome_ecms_infoclass_news 新闻采集规则记录表 phome_ecms_info ...

  6. 帝国empirecms数据库数据表详细说明

    表名   解释 phome_ecms_infoclass_news 新闻采集规则记录表 phome_ecms_infotmp_news 采集临时表 phome_ecms_news 新闻主数据记录表 p ...

  7. 帝国CMS数据库数据表详细说明

    表名                                             解释 phome_ecms_infoclass_news 新闻采集规则记录表 phome_ecms_inf ...

  8. laravel5Eloquent模型与数据表的创建

    下面是有关管理员模型与表的创建 生成模型时同时生成数据库迁移文件 在生成的迁移文件中添加字段 运行命令行生成数据表 命令进行混合运用 生成工厂文件,数据填充文件 工厂模型代码 数据填充文件代码 数据填 ...

  9. EXCEL 如何将多个工作表或工作簿合并到一个工作表

    在使用Excel 时,我们经常需要将多个工作表或工作簿合并到一个工作表中,这样我们就能快速地对数据进行分析和统计.对于一般用户而言,除了复制每个工作表后再粘贴,没有其他什么方法了.如果只是合并少数几个 ...

随机推荐

  1. Python实现Json结构对比的小工具兼谈编程求解问题

    摘要: 通过使用Python编写一个解析Json结构对比的小工具,来提炼编程求解的通用步骤和技巧. 难度: 初级 先上代码. jsondiff.py #!/usr/bin/python #_*_enc ...

  2. linux常用命令:less 命令

    less 工具也是对文件或其它输出进行分页显示的工具,应该说是linux正统查看文件内容的工具,功能极其强大.less 的用法比起 more 更加的有弹性.在 more 的时候,我们并没有办法向前面翻 ...

  3. react脚手架构建工程

    https://blog.csdn.net/qtfying/article/details/78665664 第二步:安装less包: https://segmentfault.com/a/11900 ...

  4. yum安装时提示app is currently holding the yum lock; waiting for it to exit

    yum安装时出现下面情况 可能是yum升级一些文件时,出现这种情况 解决方法: #rm -f /var/run/yum.pid 强制关掉yun进程

  5. 代码静态扫描工具sonar

    一.SonarQube整体介绍 SonarQube为静态代码检查工具,采用B/S架构,帮助检查代码缺陷,改善代码质量,提高开发速度,通过插件形式,可以支持Java.C.C++.JavaScripe等等 ...

  6. 又一国产855旗舰突然现身:支持5G

    12月28日消息,中国联通官方微博放出了vivo NEX 5G版样机.如图所示,该机搭载骁龙855移动平台及X50 5G调制解调器. 早在8月30日,vivo就宣布完成了面向商用5G智能手机的软硬件开 ...

  7. 查询oracle数据库里面所有的表名

    如果是当前用户,"select * from tab"即可

  8. Mysql错误:ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction

    昨晚添加完索引之后, 查询整表的时候抛出Lock wait timeout exceeded; try restarting transaction, 吓死小白的我, 为什么条件查询可以, 整表查不了 ...

  9. switch to hexo !

    用 hexo 搭了个博客 但是由于本博客内容过多,所以对于少数内容搬迁,而且本博客和那个博客相关联,但是这个博客不再更新. 新站地址 再见!

  10. 20145315《网络对抗》——注入shellcode以及 Return-to-libc攻击实验

    shellcode 准备一段Shellcode 我用的老师的shellcode:\x31\xc0\x50\x68\x2f\x2f\x73\x68\x68\x2f\x62\x69\x6e\x89\xe3 ...