[英]Call VBA excel macro from word to paste a table that updates based on drop-down list in word
这是一个很好的。 首先,我今天开始学习VBA,所以要保持柔和。 因此,我在EXCEL 2007中有了这个vba宏,它可以根据用户从3个下拉菜单中的选择自动隐藏/显示表中的行。 仅供参考,该表会根据用户的选择隐藏不需要的行,从而从包含所有可能选择的主表中自动更新。
现在,我想将其提升到另一个层次。 我想要的是能够从WORD 2007调用宏,以便将该表复制到Word文档的所需位置。 为了实现这一点,下拉菜单将需要在Word文档中,并且EXCEL宏将必须从Word文档中“读取”所选值以构造表。 换句话说,用户将永远不会看到EXCEL部分,并且将基于他在下拉菜单中的选择而在Word文档中获得一个表格。
我插入了建立表格的excel宏。 最终结果将是驱动IF语句的变量C1,C2和C3将成为WORD下拉菜单中的变量
Sub Sequence()
Application.ScreenUpdating = False
ActiveSheet.Cells.EntireRow.Hidden = False
If Range("C2").Value = 2 Then
Rows("48:67").Hidden = True
Else
Rows("48:67").Hidden = False
End If
If Range("C3").Value = 2 Then
Rows("6:7").Hidden = True
Else
Rows("6:7").Hidden = False
End If
If Range("C1").Value = 1 Then
Rows("9:12").Hidden = True
Rows("14:17").Hidden = True
Rows("19:22").Hidden = True
Rows("24:27").Hidden = True
Rows("29:47").Hidden = True
Rows("48:51").Hidden = True
Rows("53:56").Hidden = True
Rows("58:61").Hidden = True
Rows("63:66").Hidden = True
j = 1
k = -2
For i = 6 To 67
If Rows(i).Hidden = False Then
Range("A" & i) = j
j = j + 1
Range("B" & i) = k
k = k + 1
End If
Next i
End If
If Range("C1").Value = 2 Then
Rows("9").Hidden = True
Rows("11").Hidden = True
Rows("13").Hidden = True
Rows("15").Hidden = True
Rows("17").Hidden = True
Rows("19").Hidden = True
Rows("21").Hidden = True
Rows("23").Hidden = True
Rows("25").Hidden = True
Rows("27").Hidden = True
Rows("29:31").Hidden = True
Rows("33:35").Hidden = True
Rows("37:39").Hidden = True
Rows("41:43").Hidden = True
Rows("45:47").Hidden = True
Rows("48:51").Hidden = True
Rows("53:56").Hidden = True
Rows("58:61").Hidden = True
Rows("63:66").Hidden = True
j = 1
k = -2
For i = 6 To 67
If Rows(i).Hidden = False Then
Range("A" & i) = j
j = j + 1
Range("B" & i) = k
k = k + 1
End If
Next i
End If
If Range("C1").Value = 3 Then
Rows("9").Hidden = True
Rows("11").Hidden = True
Rows("13").Hidden = True
Rows("15").Hidden = True
Rows("17").Hidden = True
Rows("19").Hidden = True
Rows("21").Hidden = True
Rows("23").Hidden = True
Rows("25").Hidden = True
Rows("27").Hidden = True
Rows("29").Hidden = True
Rows("31").Hidden = True
Rows("33").Hidden = True
Rows("35").Hidden = True
Rows("37").Hidden = True
Rows("39").Hidden = True
Rows("41").Hidden = True
Rows("43").Hidden = True
Rows("45").Hidden = True
Rows("47").Hidden = True
Rows("48:50").Hidden = True
Rows("52:54").Hidden = True
Rows("56:58").Hidden = True
Rows("60:62").Hidden = True
Rows("64:66").Hidden = True
j = 1
k = -2
For i = 6 To 67
If Rows(i).Hidden = False Then
Range("A" & i) = j
j = j + 1
Range("B" & i) = k
k = k + 1
End If
Next i
End If
If Range("C1").Value = 4 Then
j = 1
k = -2
For i = 6 To 67
If Rows(i).Hidden = False Then
Range("A" & i) = j
j = j + 1
Range("B" & i) = k
k = k + 1
End If
Next i
End If
Range("A5:D67").Copy
Application.ScreenUpdating = True
End Sub
您是否要从Word调用Excel中的宏? 就是这种情况,您可以在Word中执行此操作:
Sub excel()
Dim excel As Object
Dim wb As Object
Dim str As String
Set excel = CreateObject("Excel.Application")
Set wb = excel.workbooks.Open("D:\Profiles\scklam\Desktop\Book2.xls")
'Run the macro you want
excel.Run "test2"
str = wb.sheets(1).Range("A1")
Selection.TypeText (str)
wb.Save
wb.Close
Set wb = Nothing
Set excel = Nothing
End Sub
在此示例中,我在Excel中执行了一些操作,然后将单元格的值复制回Word。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.