- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个小应用程序,其中包含大约20个可以完美运行的子程序...每隔一段时间。
我在子ImportData中第一次将代码名称添加到新创建的工作表中时失败。在以下行中:ThisWorkbook.VBProject.VBComponents(wsTarget.CodeName).Name = "Customers"
下面的代码包含三个可以重新创建问题的子。重要说明:我可以连续多次运行子ImportData,而不会出现任何问题,但是如果我连续两次调用子“ Sync()”,它将在第二次尝试中失败,但是在第三次尝试中运行良好,依此类推(也许它不喜欢奇数。)
任何关于为什么发生这种情况的想法将不胜感激。
FYT:我正在Mac的Excel中运行此代码
Public LastRow As Long
Private wks As Worksheet
Sub Sync()
Call ImportData
Call SyncBoth
End Sub
Public Sub ImportData()
'++++++++++++++++++++++++++++++++++++++++++++++++++++++
'+++++ 1. ImportData will allow user to select file to import data from
'+++++ 2. Copy both the Customers and Vendors data to their respective sheets
'++++++++++++++++++++++++++++++++++++++++++++++++++++++
Dim wsSource As Worksheet
Dim wsTarget As Worksheet
Dim LastRow As Long
Dim MaxDate As Date
Dim ShCount As Integer
Dim SourceFile As String
SourceFile = "/Users/phild/Documents/RTPro/Customer and Vendor Raw Sync.xlsm"
Dim SourceWb As Workbook
Set SourceWb = Workbooks.Open(SourceFile)
Dim TargetWb As Workbook
Set TargetWb = ThisWorkbook
Dim sheet As Worksheet
For ShCount = 1 To 2
Select Case ShCount
Case 1
Set wsSource = SourceWb.Worksheets("Sheet1") 'Set Worksheet to copy data from
ThisWorkbook.Sheets("Customers").Delete 'Delete old Customer worksheet in this worksheet
Set sheet = ThisWorkbook.Sheets.Add 'Create New Customer woeksheet in this woekbook
sheet.Name = "Customers" 'Name new Customer worksheet
Set wsTarget = ThisWorkbook.Worksheets("Customers") 'Set Customers ws as the target ws
Debug.Assert ThisWorkbook.VBProject.Name <> vbNullString '<--Force the VBE to exist. Don't pollute the Immediate window
ThisWorkbook.VBProject.VBComponents(wsTarget.CodeName).Name = "Customers" 'Give Customers a Code name
'THE LINE OF CODE ABOVE RESULTS IN A Runtime error '32813"
' Method 'Name' of object '+VBComponent' failed
' EVERY OTHER TIME I RUN THE SUB Sync()
Case 2
Set wsSource = SourceWb.Worksheets("Sheet3") 'Set Worksheet to copy data from
ThisWorkbook.Sheets("Vendors").Delete 'Delete old Vendors worksheet in this worksheet
Set sheet = ThisWorkbook.Sheets.Add 'Create New Vendor worksheet in this woekbook
sheet.Name = "Vendors" 'Name new Vendor worksheet
Set wsTarget = ThisWorkbook.Worksheets("Vendors") 'Set Customers ws as the target ws
Debug.Assert ThisWorkbook.VBProject.Name <> vbNullString '<--Force the VBE to exist. Don't pollute the Immediate window '
ThisWorkbook.VBProject.VBComponents(wsTarget.CodeName).Name = "Vendors" 'Give Vendors a Code name
End Select
Call CleanTarget(wsTarget)
LastRow = Find_LastRow(wsSource)
wsSource.Range("A1:Z" & LastRow).Copy Destination:=wsTarget.Range("A1")
Next ShCount
SourceWb.Close
End Sub
Sub SyncBoth()
Dim ShCount As Integer
For ShCount = 1 To 2
Select Case ShCount
Case 1
Set wks = Customers 'Work in sheet("Customers")
LastRow = Find_LastRow(wks) 'Last row of "Customers"
Case 2
Set wks = Vendors 'Work in sheet("Vendors")
LastRow = Find_LastRow(wks) 'Last row of "Vendors"
End Select
Debug.Print wks.Name
Next ShCount
'Normally I have about 10 subs here that are called sequentially. But this is enough the cause the errorw
End Sub```
最佳答案
您正在运行时修改宿主VBA项目-Sheet1
的代码名称标识符是一个编译时的项目全局范围对象:即使未在任何地方使用它,也有合法的机会更改它需要重新编译项目。
因此,代码可以很好地运行,直到通过重命名全局对象来解决问题为止。由于编译后的代码与项目中的实际VBComponent
匹配,因此下一次运行现在运行良好。
考虑将宏放在一个单独的VBA项目中,该宏提示在哪个启用宏的工作簿中重命名组件:因为该VBA项目不会是已编译和运行的VBA代码,所以它应该“正常工作”。
关于excel - VBProject.VBComponents(wsTarget.CodeName).Name =代码每隔一次失败。为什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60711684/
此问题仅针对代号一。 用例 一些应用程序,如 Instagram,具有 x 轴可滚动框,如本视频所示: https://www.informatica-libera.net/videoLavoro/V
您好,我正在使用 Codename One 和 Parse Server 将数据库保存在我的移动应用程序中,但我想将查询的每个结果放在一个按钮中,因为我需要单击列表中的每个元素。 ParseQuery
我创建了一个自定义日历,每当我单击日历按钮时,我都会尝试调用选择器,但它对我不起作用,以下是我的应用程序代码,该代码无法正常工作。那么我如何修改此代码以便能够从 ActionEvent 调用选取器?
有时,在决定如何构建图形界面之前,查阅 Codename One 提供的组件列表很有用。我有以下 list 。你能告诉我它是绝对完整的还是遗漏了什么?谢谢 Labels Label
我正在尝试使用CodeName One构建一个非常简单的用户界面。我想要一个矩形屏幕(用于显示图像)和其下方的按钮。我找不到类似矩形屏幕面板的东西,所以我只是贴了一个标签。 层次结构如下所示: 容器(
我正在尝试向标题/标题栏添加一个图标。 用代码更改标题本身效果很好: setTitle("测试"); 但是我无法找到向其添加图标的方法。这是我尝试过的方法,但没有成功: Image img =
我试图通过它的 CodeName 属性引用新添加的工作表。问题是 CodeName 返回空字符串,除非从调试器运行。 Set tableSheet = Worksheets.Add(After:=Wo
有没有办法在 Picker 组件中将选定的文本显示为多行? Picker 组件从 Button 扩展而来,它似乎不是一种将文本显示为多行的简单方法。 最佳答案 您可以克隆 Picker 类并将其命名为
我的应用程序使用 cn1-codescan.cn1lib 返回不受支持。当我使用已弃用的 CodeScanner (com.codename1.codescan.*) 时,扫描仪应用程序可以工作,但永
我已经创建了一个表单并添加了一个容器。我正在尝试使用此代码向容器中添加一个组件 Component container = new Container(new GridBagLayout())
我的应用程序使用一种表单,导航包括替换主容器。我有一个带有侧菜单、 Logo 、后退和退出命令的工具栏。我想在某些特定页面中禁用后退命令。command.setEnabled(false) 不起作用,
我刚刚在 Eclipse Oxygen 上安装了 Codename One(通过 eclipse 市场),并在 64 位 Ubuntu 14.04 LTS 下安装了 Java 8。我按照“入门”说明创
上下文: 开始为 android 和 ios 编写移动应用程序。 寻找许多替代方案。受不了 html5/webview 的东西。大多数时候它是缓慢的。我尝试了很多演示应用程序(phonegap/ste
也许我只是很难理解它。我从我所做的研究中了解它是如何工作的,尤其是这个问题:How does Codename One work? 但是如果我想拦截 Android 中的传入文本怎么办?这对 iOS
我在使用代号为 1 的 android 拦截 url 时遇到问题。我使用构建提示 ios.urlScheme 和 ios.plistInject 使其在 ios 上运行良好。我用于 android 的
我正在尝试了解如何使用 Codename One 服务器推送正确的通知。我想发送基本上看起来像 LocalNotifications 的通知- 带有标题、正文、角标(Badge)等。 然而在docum
我想在我的代号 One 应用程序中添加一个帮助屏幕。由于文本与其他字符串一样长,我想将它放在一个单独的文件中并将其添加到应用程序包中。 我该怎么做?将文本文件放在哪里,如何轻松地将其一次性读取到字符串
我有一个带有文本字段的 Android 应用程序。当我开始打字时,键盘将背景图像向上推。 我希望图像保留在原位,而键盘覆盖它。 将布局更改为 BoxLayout 或 BorderLayout 对背景图
我正在使用 Codename One 从数据库中获取数据并将其显示在表格中。 它运行良好,现在我正尝试添加一个功能来限制表格中显示的项目数量。为此,我想从数据库中检索选定数量的列。 不幸的是,常见的j
Toolbar API没有任何方法可以在左侧或右侧添加按钮(除了 SideMenus 内部)。它只允许添加命令,但命令不如按钮有用,因为我不能单独设置每个命令的样式,而我可以使用按钮来做到这一点。所以
我是一名优秀的程序员,十分优秀!