- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在努力完成以下任务:
使用 VBA 循环遍历一个表格,并使用以下三个参数分配餐 table 上的座位:
1) 个人的优先级分数。
2) 个人对坐在哪张 table 上的偏好。
3) table 的座位数。
理想情况下,VBA 会从 Priority 1 组的第一条记录开始,分配尽可能多的人可以放在 Table1 中,然后继续根据他们的偏好分配 Priority 1 个人,同时检查他们的首选表是否是满负荷运转。
在为所有优先级为 1 的个人分配了一个表(在表对象中指定了“Table_Assignment”值)之后,VBA 移至优先级为 2 的个人,依此类推。
在我的数据库中,我有下表(名为“tbl_Assignments”的表对象):
RecordID | Table_Assignment | Priority | Title | Preference_1 | Preference_2 |... Preference_n
001 1 CEO Table1
002 1 CEO-spouse Table1
003 1 VP Table1 Table2
004 1 VP-spouse Table1 Table2
005 2 AVP Table1 Table2
006 2 AVP-spouse Table1 Table2
007 3 Chief counsel Table1 Table2 Table_n
008 3 COO Table1 Table2 Table_n
此外,我创建了一个查询,告诉您在对表进行分配时还剩下多少空缺(名为“qry_capacity_sub1”的查询对象):
TableID | Maximum_seating | Seats_taken | Vacancies
Table1 4 3 1
Table2 4 2 2
Table3 4 0 4
Table4 4 1 3
我曾尝试编写带有循环的 VBA,这将实现我的目标,即在表格 ('tbl_Assignments') 中循环并在单击窗体上的命令按钮后为 'Table_Assignment' 字段分配值。
更新 (11/09/2014):将 VBA 更新到我现在在此过程中的位置。对 VBA 的更改也反射(reflect)了 Jérôme Teisseire 的建议。
下面的 VBA 是从我在这里看到的开始的:Looping Through Table, Changing Field Values
Private Sub Command0_Click()
Dim db As DAO.Database
Dim rs As DAO.Recordset
Dim strSQL As String
Set db = CurrentDb()
strSQL = "Select RecordID, Table_Assignment, Priority, Preference_1, Preference_2, Preference_3 FROM tbl_Assignments WHERE Priority =1"
Set rs = db.OpenRecordset(strSQL)
On Error GoTo Err_Handler
Do Until rs.EOF
With rs
If there are seats available at your first preferred table Then
.Edit
!Table_Assignment = rs!Preference_1
.Update
.MoveNext
End If
If the first table you preferred has reached capacity, and there are seats left in your second preferred table Then
.Edit
!Table_Assignment = rs!Preference_2
.Update
.MoveNext
End If
'..keep checking each the person's preferred tables. If they cannot be assigned a table because their preferred tables are at capacity...
Else
.Edit
!Table_Assignment = "Unassigned"
.Update
.MoveNext
End With
Loop
rs.Close
Exit_Handler:
Set rs = Nothing
Set db = Nothing
Exit Sub
Err_Handler:
MsgBox "You need to debug"
Resume Exit_Handler
End Sub
最佳答案
可能 qry_capacity_sub1 依赖于 tbl_Assignments,当您尝试同时查询和更新它时,它会导致 Access 崩溃。为了验证这一点,您尝试用一些虚假检查替换您的 DLookup 条件,例如
If True Then
...
只是为了验证其余代码是否正常工作。
我还认为您的代码在 DLookup 条件中存在另一个逻辑错误 - “TableID='Preference_1'”将搜索“Preference_1”字符串而不是列值。我认为它一定是 liek "TableID='"+ rs!Preference_1 + "'",但恐怕这也无济于事。
我建议您将每个表的空缺缓存到 in-memory dictionary 中并在每次分配表格时减少空缺。所以代码可能类似于下面给出的。另请注意,最好不要将 MoveNext 嵌套在任何 If 中,以确保不会出现死循环(这也可能是导致崩溃的原因)。
Private Sub Command0_Click()
Dim db As DAO.Database
Dim rs As DAO.Recordset
Dim strSQL As String
Dim VacancyPerTable As New Scripting.dictionary
Set db = CurrentDb()
Set rsVac = db.OpenRecordset("SELECT DISTINCT TableID, Vacancies FROM qry_capacity_sub1")
While Not rsVac.EOF
VacancyPerTable.Add rsVac!TableID, rsVac!Vacancies
Loop
rsVac.Close
strSQL = "Select RecordID, Table_Assignment, Priority, Preference_1, Preference_2, Preference_3 FROM tbl_Assignments WHERE Priority =1"
Set rs = db.OpenRecordset(strSQL)
On Error GoTo Err_Handler
Do Until rs.EOF
With rs
If VacancyPerTable(!Preference_1) > 0 Then
.Edit
!Table_Assignment = rs.Fields(3)
.Update
VacancyPerTable(!Preference_1) = VacancyPerTable(!Preference_1) - 1
ElseIf VacancyPerTable(!Preference_2) > 0 Then
.Edit
!Table_Assignment = rs.Fields(4)
.Update
VacancyPerTable(!Preference_2) = VacancyPerTable(!Preference_2) - 1
ElseIf VacancyPerTable(!Preference_3) > 0 Then
.Edit
!Table_Assignment = rs.Fields(5)
.Update
VacancyPerTable(!Preference_3) = VacancyPerTable(!Preference_3) - 1
Else
.Edit
!Table_Assignment = "UnAssigned"
.Update
End If
.MoveNext
End With
Loop
rs.Close
Exit_Handler:
Set rs = Nothing
Set db = Nothing
Exit Sub
Err_Handler:
MsgBox "You need to debug"
Resume Exit_Handler
End Sub
关于database - 如何循环遍历某些记录、检查查询并使用 VBA 有条件地分配字段值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26813497/
我有一个 VBA 脚本,可以将数据从一张表复制到另一张表。复制的数据被放入公式中,计算出的数量被复制回原始工作表。我正在尝试获取它,以便 VBA 脚本为每一行执行此操作。我有 1000 行数据。 Su
如何让 excel 在我的“临时”表上列出所有可用的环境变量?下面的代码没有为我返回任何东西...... Sub ListEnvironVariables() Dim strEnviron A
好的,这就是我想要完成的事情:我正在尝试将所有 VBA 代码从“Sheet2”复制到“Sheet 3”代码 Pane 。我不是指将模块从一个模块复制到另一个模块,而是指 Excel 工作表对象代码。
我正在做一个项目来使用 rule-triggered 处理一些传入的 Outlook 邮件。 VBA 代码。 但是,我不想在代码需要更改的任何时候手动更新每个用户收件箱的代码。所以我的想法是把一个文本
我想从另一个代码 VBA 中评论包含 Msg Box 的行。我正在尝试使用 Library VBA EXTENSIBILITY,但我没有找到解决方案。 欢迎任何帮助。 这是我的代码: Sub Comm
我正在尝试编写程序的最后一部分,我需要从 Access 文档中提取数据并将其打印到新的工作簿中。 首先,我将获取产品供应商的名称并创建一个包含每个供应商名称的工作表,然后我想遍历每个工作表并打印每个供
我有一个要求,我试图查找数据中的日期是否大于或等于当前日期,那么它应该显示"is"。 这是我的代码, RDate = Application.WorksheetFunction.if(RSDate>=
我试图想出一个宏来检查单元格中是否存在任何数字值。如果存在数字值,请复制该行的一部分并将其粘贴到同一电子表格内的另一个工作表中。 Sheet1 是包含我所有数据的工作表。我正在尝试查看 R 列中是否有
我有一个具有密码保护(防止未经授权访问宏)的 VBA 宏,它按预期运行。用户单击按钮,宏运行。内容大致如下: Sub sample() ActiveSheet.Unprotect Pass
我想通过VBA删除工作表中包含的VBA代码。目前,我有一个代码可以将工作表复制到新工作簿并从中删除所有图像。但是,这些图像被设置为在代码中的 Worksheet_Activate 上执行操作,每当我轻
我有一个 vba 代码,它指定要查看的特定工作表名称,例如工作表 2, 但是,如果有人忘记将工作表名称更改为sheet2,我可以添加一段动态代码来自动更改调用工作表名称的vba代码吗?例如,从左边算起
VBAExcel 2016 如果执行某些代码后该范围的列数较少,我将尝试动态调整该范围的大小。引用了 MS 文件和各种在线示例,但没有成功。 https://msdn.microsoft.com/en
我在任何地方都找不到这个问题。在 Visual Basic (excel) 中,我可以按 F8 并循环浏览每一行。但是假设我想开始子程序,然后在执行前两行之后,我想跳到第 200 行。到目前为止,我一
这是我昨天的问题的补充,所以我开始一个新问题。基本上,我在 excel 的工作表上得到不同范围的数据,并且数据范围每周都不同,因此最后使用的列和最后使用的行会有所不同。 我想根据名称合并第 3 行和第
我的想法是创建一个函数来传递这样的双数组: Function pass(a() As Double, b() as double) As Boolean Dim i As Integer, j As
我正在使用 vlookup 运行 VBA 代码,但是,它需要几秒钟才能完成,尽管具有行的工作表只有不到 150 行。 滞后主要出现在 col 23 的生成期间。 包含此代码的主工作表有大约 2300
我在 VBA 中有一个小问题,我想将 Range 函数的行和列以 String 格式放置,如下所示: debut = "BH" & LTrim(Str(i)) fin = "DB" &
我正在尝试使用 Visual Basic 编写 Webcrawler。我有一个包含链接的列表,存储在 Excel 中(第 1 列)。然后宏应打开每个链接并将网站中的某些信息添加到 excel 文件中。
我正在尝试自动生成报告(请原谅我缺乏 Excel 经验),但遇到了这个错误。在单元格中显示#NAME。代码应为工作簿另一页上的所有列 E 选择单元格和 COUNTIF <1。这是一个简单的语法错误吗?
我正在使用“Sheet1”上的命令按钮使用 VBA 创建图表,但是该图表正在添加到另一个工作表(“Sheet2”)。 添加图表后,我使用以下代码根据 DataLabel 值对条形图进行着色并更改 Da
我是一名优秀的程序员,十分优秀!