创建自安装的宏? [英] Creating a self install macro?

查看:176
本文介绍了创建自安装的宏?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

您好我创建的宏为我的合作工人。目前的方法,我对分配给另一台计算机进入VBA编辑器和进口。

Hello I create many macros for my co workers. The current method I have for distributing to another computer is going into the vba editor and importing.

我真的想做出一种安装程序的宏,允许用户安装一个新的宏,而不必进入编辑器。我不知道这甚至有可能,但任何想法,欢迎!

I would really like to make a kind of "installer" for macros that would allow the user to install a new macro without having to go into the editor. I'm not sure this is even possible but any ideas are welcome!

谢谢!

推荐答案

您需要启用在参考Microsoft脚本运行时库。 (VBE - >工具 - >引用勾选)

You need to enable Microsoft Scripting Runtime library under references. (VBE -> Tools -> References. Check the box.)

基本上,你创建包含要安装宏的code字符串。很显然,该字符串可能是很长的与code多行,所以你可能需要多个字符串变量。

Basically, you create a string that holds the code of the macro you want to install. Obviously, the string could be really long with many lines of code so you might need several string variables.

Dim toF As Workbook
Dim codeMod As CodeModule
Dim code As String
Dim fso As Scripting.FileSystemObject
Dim folder As folder
Dim name As String, file As String

Application.ScreenUpdating = False

Set fso = New FileSystemObject
Set folder = fso.GetFolder("C:\folder\here")
name = nameOfFileHere
file = folder & "\" & name

Set toF = Workbooks.Open(file)
'modify ThisWorkbook  to place it elsewhere
Set codeMod = toF.VBProject.VBComponents("ThisWorkbook").CodeModule

'erase everything if code already exists
If codeMod.CountOfLines > 0 Then
    codeMod.DeleteLines 1, codeMod.CountOfLines
End If

'dump in new code
code = _
"Private Sub Workbook_Open()" & vbNewLine & _
"   Dim user as String" & vbNewLine & _
"   Dim target as String" & vbNewLine & _
"   user = Application.UserName" & vbNewLine & _
"   target = """ & findUser & """" & vbNewLine & _
"   If user = target then" & vbNewLine & _
"   MsgBox ""I just dumped in some code.""" & vbNewLine & _
"   End if" & vbNewLine & _
"End Sub" & vbNewLine

With codeMod
    .InsertLines .CountOfLines + 1, code
End With

Application.ScreenUpdating = True

这篇关于创建自安装的宏?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆