Excel VBA 逐个激活现在打开的工作簿

Sub自动填充()Application.ScreenUpdating=False'关闭屏幕更新Application.DisplayAlerts=False'关闭提示窗... Sub 自动填充()

Application.ScreenUpdating = False '关闭屏幕更新

Application.DisplayAlerts = False '关闭提示窗口

Dim i As Integer, fn As Variant, sht As Variant

fn = Array(表1.xls,表2.xls, 表3.xls, 表4.xls, 表5.xls, 表6.xls, 表7.xls)

sht = Array(表1, 表2, 表3, 表4, 表5, 表6, 表7)

For i = 0 To 6

Windows("fn(i)").Activate
Cells.Select
Selection.Copy
Windows("汇总.xls").Activate
Sheets("sht(i)").Select
Cells.Select
With Selection
.PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks:=False, Transpose:=False
.PasteSpecial Paste:=xlPasteComments, Operation:=xlNone, SkipBlanks:=False, Transpose:=False
End With
Windows("fn(i)").Activate
ActiveWindow.Close 'savechangs:=False '关闭窗口不保存
fn(i) = fn(i + 1)
sht(i) = sht(i + 1)
Next i

i = 0

For i = 0 To 6
Windows("汇总格式.xls").Activate
Sheets("格式").Select
Cells.Select
Selection.Copy
Windows("汇总.xls").Activate
Sheets("sht(i)").Select
Selection.PasteSpecial Paste:=xlPasteFormats, Operation:=xlNone, _
SkipBlanks:=False, Transpose:=False
sht(i) = sht(i + 1)
Next i
Application.DisplayAlerts = True '打开提示窗口

ActiveWorkbook.SaveAs Filename:="D:\临时文件\汇总.xls", FileFormat _
:=xlNormal, Password:="", WriteResPassword:="", ReadOnlyRecommended:= _
False, CreateBackup:=False '文件保存路径及文件名
Application.ScreenUpdating = True '打开屏幕更新
ActiveWindow.Close
Windows("汇总格式.xls").Activate

End Sub

我是初学者,根据自己录的宏写的,有好多错误,希望高手帮忙看看
展开
 我来答
善良的猪头3
2013-11-07 · TA获得超过2932个赞
知道大有可为答主
回答量:2522
采纳率:71%
帮助的人:2795万
展开全部
Sub 自动填充()

    Application.ScreenUpdating = False '关闭屏幕更新

    Application.DisplayAlerts = False '关闭提示窗口

    Dim i As Integer, fn As Variant, sht As Variant

    fn = Array("表1.xls", "表2.xls", "表3.xls", "表4.xls", "表5.xls", "表6.xls", "表7.xls")

    sht = Array("表1", "表2", "表3", "表4", "表5", "表6", "表7")

    For i = 0 To 6

        Windows(fn(i)).Activate

        Cells.Select

        Selection.Copy

        Windows("汇总.xls").Activate

        Sheets(sht(i)).Select

        Cells.Select

        With Selection

            .PasteSpecial Paste:=xlPasteValues, Operation:=xlNone, SkipBlanks:=False, Transpose:=False

            .PasteSpecial Paste:=xlPasteComments, Operation:=xlNone, SkipBlanks:=False, Transpose:=False

        End With

        Windows(fn(i)).Activate

        ActiveWindow.Close False 'savechangs:=False '关闭窗口不保存

       ' fn(i) = fn(i + 1)

       ' sht(i) = sht(i + 1)

    Next i

    i = 0

    For i = 0 To 6

        Windows("汇总格式.xls").Activate

        Sheets("格式").Select

        Cells.Select

        Selection.Copy

        Windows("汇总.xls").Activate

        Sheets(sht(i)).Select

        Selection.PasteSpecial Paste:=xlPasteFormats, Operation:=xlNone, _

            SkipBlanks:=False, Transpose:=False

    sht(i) = sht(i + 1)

    Next i

    Application.DisplayAlerts = True '打开提示窗口


    ActiveWorkbook.SaveAs Filename:="D:\临时文件\汇总.xls", FileFormat _

        :=xlNormal, Password:="", WriteResPassword:="", ReadOnlyRecommended:= _

        False, CreateBackup:=False '文件保存路径及文件名

    Application.ScreenUpdating = True '打开屏幕更新

    ActiveWindow.Close

    Windows("汇总格式.xls").Activate

End Sub
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式