说明(2017.3.26):

1. 还没写完,写到新建文件夹了,下一步新建word,重命名,查找点拨,把点拨复制进去,因为要给点拨编号,应该会很麻烦

 Public Sub test1()
Dim path
Dim filename
Dim folders( To )
Dim i%, j%
i =
j =
' 1. 先获取所有的文件夹
path = ThisWorkbook.path & "\oriFolder\"
folders() = path
' 这里的folders数组和下面的classes数组只设置了100个长度,是为了调试方便,不然有时会出现大量空行,实际中可以增大。
' dir第二次无参数调用,返回的是同一个文件夹下的第二个文件!!
' filename = Dir(folders(i), vbDirectory)这里filename获取的首先是folders(1)路径下的文件夹"."
' dir找到第一个文件夹".",这时i=1,进入do循环,把oriFolder这一层的文件夹都dir出来(101和102),
' 找到一个文件夹就把j加1(最后j=3),把folders(i)修改为"."路径,101路径和102路径,里面的do until循环就做了这么个事
' do until做完之后,i要加1了,变成2,这时的filename = Dir(folders(i), vbDirectory),folders(2)就是do until循环里已经修改的101路径了,
' 继续do until循环,j目前=3,然后开始增加,目的是让folders(j)数组继续往后增加元素,等把101路径里所有文件夹路径添加进去之后,
' i变成3,再开始遍历102文件夹
' 如果101里面还有文件夹,就等把101和102都遍历完后,因为i每次只加1,而j是只要有一个文件夹就加1,
' 所以只要i没有到j的数量,就会一直遍历下去,把所有的子文件遍历出来
Do While i <= j
filename = Dir(folders(i), vbDirectory) ' filename="."
Do Until filename = ""
If InStr(filename, ".") = Then
j = j +
' 当i=1的时候,folders(j)中的1,2,3分别是",",101,102目录
folders(j) = folders(i) & filename & "\"
End If
filename = Dir
Loop
i = i +
Loop
' For p = 1 To UBound(folders)
' If folders(p) <> "" Then
' Debug.Print (folders(p))
' End If
' Next
' 2. 从每个文件夹里获取所有课,存入一个数组
Dim classes( To )
Dim class
Dim p
Dim q
p =
q = For p = To UBound(folders)
If folders(p) <> "" Then
class = Dir(folders(p) & "*.*")
Do Until class = ""
classes(q) = folders(p) & class
q = q +
class = Dir
Loop
End If
Next '3. 在desFolder里新建文件夹,生成点拨rtf
Dim path2
'先来一套正则相关的dim as
Dim reg As RegExp
Dim myMatches As MatchCollection
Dim myMatch As match
Dim books( To )
Dim bNum
Dim m
Dim n
n =
m =
bNum =
'再来一套操作word的dim as
Dim wordApp As Word.Application
Set wordApp = New Word.Application
path2 = ThisWorkbook.path & "\desFolder\"
Set reg = New RegExp
'获取所有版本文件夹名
filename2 = Dir(path, vbDirectory)
Do Until filename2 = ""
If InStr(filename2, ".") = Then
books(bNum) = filename2
bNum = bNum +
End If
filename2 = Dir
Loop
'在desFolder里面生成版本文件夹
For m = To UBound(books)
' books(m)不为空,并且文件夹不存在,就新建文件夹
If books(m) <> "" And Dir(path2 & books(m), vbDirectory) = "" Then
MkDir (path2 & books(m))
' 新建word,命名为“01_《繁星》_DianBo.doc”
' 打开每课,查找点拨,复制到word中,格式为1-1-2-1-1【点拨】,第1单元-第1课-2复习-1课堂回顾-第1个点拨 For n = To UBound(classes)
If classes(n) <> "" Then
wordApp.Documents.Open (classes(n)) End If
Next
End If
Next
'For x = 1 To UBound(classes)
' If classes(x) <> "" Then
' reg.Global = True '全局匹配
' reg.IgnoreCase = True '忽略大小写
' reg.Pattern = "(,*)?101_.*" '正则表达式
' Set myMatches = reg.Execute(classes(x)) '匹配到的结果返回到myMatches集合
' For Each myMatch In myMatches '遍历myMatches集合
' If myMatch <> "" Then
' Debug.Print (classes(x))
' End If
' Next
'
' End If
'Next End Sub

VBA学习笔记(9)--生成点拨(1)的更多相关文章

  1. GIS案例学习笔记-三维生成和可视化表达

    GIS案例学习笔记-三维生成和可视化表达 联系方式:谢老师,135-4855-4328,xiexiaokui#qq.com 目的:针对栅格或者矢量数值型数据,进行三维可视化表达 操作时间:15分钟 案 ...

  2. flink学习笔记-快速生成Flink项目

    说明:本文为<Flink大数据项目实战>学习笔记,想通过视频系统学习Flink这个最火爆的大数据计算框架的同学,推荐学习课程: Flink大数据项目实战:http://t.cn/EJtKh ...

  3. VBA学习笔记

    这是一个学习VBA编程的学习笔记. 一. 介绍 二. 使用手册 2.1. 如何在Excel2010中开始使用VBA? 2.2. 如何使用VBA编辑器进行编程? 三. 语法说明 3.1 数据类型 3.2 ...

  4. VBA 学习笔记 - 变量与常量

    学习资料:https://www.yiibai.com/vba/vba_variables.html 变量和常量命名规则 必须以字母开头 不能包含空格.句点(.).感叹号(!)或字符@,&,$ ...

  5. VBA 学习笔记 - 输入框

    学习资料 https://www.yiibai.com/vba/vba_input_box.html 输入框 InputBox 函数说明 提示用户输入值.当输入值后,如果用户单击确定 按钮或按下键盘上 ...

  6. MySQL学习笔记:生成一个时间序列

    今天遇到一个需求是生成以下表格的数据,一整天24小时,每秒一行数据. 寻找颇旧,找到另外两个实现的例子,暂且学习一翻.另一个见另外一篇. DAY) AS DATE FROM ( ) AS tmp, ( ...

  7. VBA学习笔记(8)--遍历所有文件夹和文件

    说明(2017.3.26): 1. 采用的是兰色幻想教学视频中的“父子转换法” 2. 这种VBA的遍历文件夹方法非常难理解,主要是因为dir这个函数,第一次带参数调用,返回的是此目录下的第一个文件,第 ...

  8. python学习笔记(生成xml)

    想着给框架加些功能 首先想到的是生成测试报告 这里就涉及到了生成什么格式的文件 我这边就准备生成 xml 格式的文件 自己先学习了整理了下 代码如下: #!/usr/bin/env python # ...

  9. VBA 学习笔记 - 日期

    date() 返回当前的系统日期 返回格式为 YYYY/MM/DD CDate() 学习资料:https://www.yiibai.com/vba/vba_cdate_function.html 将有 ...

随机推荐

  1. JDBC 实例--JDBC通过工具类DBUtil连接到数据库,让我们不再恐惧操作数据库

    利用JDBC连接到数据库一般需要几个步骤: 1.装载驱动程序. 2.建立连接. 3.发送和执行SQL语句. 4.释放资源 首先建立一个数据库: 脚本如下: create database csdn; ...

  2. Windows下安装OpenSSL及其使用

    方法一: Windows binaries can be found here: http://www.slproweb.com/products/Win32OpenSSL.html You can ...

  3. 500 OOPS: chroot

    FTP登录时报错: 1.500 OOPS: chroot 解决方法:关闭SElinux 2.500 OOPS: vsftpd: refusing to run with writable root i ...

  4. C# 的Timer 在javascript中的实现--基于Typescript

    class Timer { //js 内置的timer对象 private _jsInnerTimerObj: any; private _enable: boolean; private _hand ...

  5. 利用 AFN 上传相册或拍照图片

    概述 自定义上传图片请求,自定义调取相册及拍照,方便多处使用时调用. 详细 代码下载:http://www.demodashi.com/demo/10718.html 由于项目中多处需要上传图片,我们 ...

  6. IBM InfoSphere DataStage 8.1 DataStage Job 开发具体解释

    简单介绍 DataStage 使用了 Client-Server 架构,server端存储全部的项目和元数据,client DataStage Designer 为整个 ETL 过程提供了一个图形化的 ...

  7. Centos定时执行python脚本

    其实就是linux的定时任务.老记不住参数,这次写下来,省着老百度.本文没有技术含量,请大家不要吐槽. ================================================ ...

  8. 【cookie】cookie和session的终极区别

    如果浏览器使用的是 cookie,那么所有的数据都保存在浏览器端,比如你登录以后,服务器设置了 cookie用户名(username),那么,当你再次请求服务器的时候,浏览器会将username一块发 ...

  9. 摘:用ADO操作数据库的方法步骤

    用ADO操作数据库的方法步骤 ADO接口简介 ADO库包含三个基本接口:_ConnectionPtr接口._CommandPtr接口和_RecordsetPtr接口. _ConnectionPtr接口 ...

  10. rpm安装PostgreSQL

    一.首先去官网下载相关的安装包 https://yum.postgresql.org/rpmchart.php 二.下载安装包 1. 最小的数据库服务器安装包: postgresql96--1PGDG ...