- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的问题:
我有多个产品结构需要能够通读。我不知道产品结构会深入到多少层。例如,我可以有以下内容:
产品 A 使用以下组件
但是组件 A3 可能是一个子组件,它有自己的产品结构,需要拉动。因此,我最终会得到产品 A 的完整产品结构,如下所示:
A用途:
等等。
我当前的代码使用一个数组来包含通过数据库查询检索到的信息,如下所示
Dim NumRecords As Integer
Dim X As Integer
Dim db As DAO.Database
Dim rs As DAO.Recordset
Dim sSQL As String
Dim PPS() As String 'Product structure returned from database query for the parent item
Dim ParentName as String ' Parent Product
Dim Plt as String ' Plant of Manufacture
Dim DBPath as string 'File path for the database
Set db = OpenDatabase(DBPath)
sSQL = "SELECT Component, NumberUsed FROM ProdStructMstr WHERE (((Parent)='" & ParentName & "') AND ((Plant)='" & Plt & "')) ORDER BY Component;"
Set rs = db.OpenRecordset(sSQL, dbOpenSnapshot)
rs.MoveLast
rs.MoveFirst
If Not rs.EOF Then NumRecords = rs.RecordCount
If NumRecords > 0 Then
ReDim PPS(NumRecords - 1, 1)
rs.MoveFirst
For X = 0 To NumRecords - 1
PPS(X, 0) = rs!Component
PPS(X, 1) = rs!NumberUsed
rs.MoveNext
Next X
Else
MsgBox "ERROR: DB Table Empty or Not Found!", vbExclamation, "DATA ERROR"
End If
Set rs = Nothing
Set db = Nothing
我遇到的问题是,它无法深入产品结构的 1 层,这意味着它不会提取子组件的信息。我想我想使用类模块和集合来解决这个问题,但我无法完全理解它。
子组件 A3 的产品结构信息列在 ProdStructMstr 表中,其中 A3 列为父组件,并列出了组件。
数据库表如何查找此内容的示例如下:
Plant | Parent | Component | NumberUsedZ | A | A1 | 1Z | A | A2 | 3Z | A | A3 | 1Z | A | A4 | 2Z | A3 | A3A | 1Z | A3 | A3B | 1Z | A3 | A3C | 2Z | A3 | A3D | 1Z | A3B | A3B1 | 1Z | A3B | A3B2 | 4Z | A3B | A3B3 | 1
最佳答案
这是一个很长的答案,但也许会有帮助
我提供了 2 个版本来说明嵌套字典在您的案例中的使用
测试数据(主要部分为浅橙色):
<小时/>Version 1
输出:
<小时/>------ ShowAllData
Item: A, SubItem: A1, Value: 1
Item: A, SubItem: A2, Value: 3
Item: A, SubItem: A3, Value: 1
Item: A, SubItem: A4, Value: 2
Item: A3, SubItem: A3A, Value: 1
Item: A3, SubItem: A3B, Value: 1
Item: A3, SubItem: A3C, Value: 2
Item: A3, SubItem: A3D, Value: 1
Item: A3B, SubItem: A3B1, Value: 1
Item: A3B, SubItem: A3B2, Value: 4
Item: A3B, SubItem: A3B3, Value: 1
------ ShowData (A3)
Item: A3, SubItem: A3A, Value: 1
Item: A3, SubItem: A3B, Value: 1
Item: A3, SubItem: A3C, Value: 2
Item: A3, SubItem: A3D, Value: 1
------ ShowData (A3B2)
Item: A3B, SubItem: A3B2, Value: 4
版本 1 有两个主要过程
ReadData()
SetItms()
<小时/>This uses dictionaries and late binding is slow:
CreateObject("Scripting.Dictionary")Early binding is fast: VBA Editor -> Tools -> References -> Add Microsoft Scripting Runtime
Option Explicit
'In VBA Editor add a reference: Tools -> References -> Add Microsoft Scripting Runtime
Private Const SEP = "------ "
Public Sub ReadData()
Const TLC = 2 'TLC = Top-level column (B: Parent)
Dim ur As Variant, r As Long, ubR As Long, parents As Dictionary
Dim lvl1 As String, lvl2 As String, lvl3 As String
ur = Sheet1.UsedRange
ubR = UBound(ur, 1)
Set parents = New Dictionary
parents.CompareMode = vbTextCompare 'or: vbBinaryCompare
For r = 2 To ubR
lvl1 = Trim(CStr(ur(r, TLC)))
lvl2 = Trim(CStr(ur(r, TLC + 1)))
lvl3 = Trim(CStr(ur(r, TLC + 2)))
SetItms Array(lvl1, lvl2, lvl3), parents
Next
ShowAllData parents
ShowData parents, "A3"
ShowData parents, "A3B2"
End Sub
<小时/>
Public Sub SetItms(ByRef itms As Variant, ByRef parents As Dictionary)
Dim ub As Long, subItms() As String, i As Long, children As Dictionary
ub = UBound(itms)
If ub > 1 Then
ReDim subItms(ub - 1)
For i = 1 To ub
subItms(i - 1) = itms(i)
Next
If Not parents.Exists(itms(0)) Then
Set children = New Dictionary
children.CompareMode = vbTextCompare 'or: vbBinaryCompare
SetItms subItms, children '<-- recursive call
parents.Add itms(0), children
Else
Set children = parents(itms(0))
SetItms subItms, children '<-- recursive call
End If
Else
If Not parents.Exists(itms(0)) Then parents.Add itms(0), itms(1)
End If
End Sub
<小时/>
接下来的 2 个子函数仅用于从字典中输出数据:ShowAllData()
和 ShowData()
Private Sub ShowAllData(ByRef itms As Dictionary)
Dim l1 As Variant, l2 As Variant
Debug.Print SEP & "ShowAllData"
For Each l1 In itms
For Each l2 In itms(l1)
Debug.Print "Item: " & l1 & ", SubItem: " & l2 & ", Value: " & itms(l1)(l2)
Next
Next
End Sub
Private Sub ShowData(ByRef itms As Dictionary, ByVal itmName As String)
Dim l1 As Variant, l2 As Variant, isParent As Boolean, done As Boolean
Debug.Print SEP & "ShowData (" & itmName & ")"
For Each l1 In itms
isParent = l1 = itmName
If isParent Then
For Each l2 In itms(l1)
Debug.Print "Item: " & l1 & ", SubItem: " & l2 & ", Value: " & itms(l1)(l2)
Next
End If
If isParent Then Exit For
Next
If Not isParent Then
For Each l1 In itms
For Each l2 In itms(l1)
done = l2 = itmName
If done Then
Debug.Print "Item: " & l1 & ", SubItem: " & l2 & ", Value: " & itms(l1)(l2)
Exit For
End If
Next
If done Then Exit For
Next
End If
End Sub
<小时/>
Version 2
输出:
<小时/>Row 1, Col 1: ---> Plant
Row 1, Col 2: ---> Parent
Row 1, Col 3: ---> Component
Row 1, Col 4: ---> NumberUsed
Row 1, Col 5: ---> Test Col 1
Row 1, Col 6: ---> Test Col 2
Row 1, Col 7: ---> Test Col 3
Row 2, Col 1: ---> Z
Row 2, Col 2: ---> A
Row 2, Col 3: ---> A1
Row 2, Col 4: ---> 1
Row 2, Col 5: ---> E1
Row 2, Col 6: ---> F1
Row 2, Col 7: ---> G1
...
Row 12, Col 1: ---> Z
Row 12, Col 2: ---> A3B
Row 12, Col 3: ---> A3B3
Row 12, Col 4: ---> 1
Row 12, Col 5: ---> E11
Row 12, Col 6: ---> F11
Row 12, Col 7: ---> G11
版本 2 只是创建 2 级字典嵌套(第 1 级 = 行,第 2 级 = 列)
<小时/>Public Sub NestedList()
Dim ur As Variant, itms As Dictionary, subItms As Dictionary
Dim r As Long, c As Long, lr As Long, lc As Long
ur = ThisWorkbook.Worksheets("Sheet1").UsedRange
Set itms = New Dictionary
itms.CompareMode = vbTextCompare 'or: vbBinaryCompare
lr = UBound(ur, 1)
lc = UBound(ur, 2)
For r = 1 To lr
Set subItms = New Dictionary
itms.CompareMode = vbTextCompare
For c = 1 To lc
subItms.Add Key:=c, Item:=Trim(CStr(ur(r, c)))
Next
itms.Add Key:=r, Item:=subItms
Set subItms = Nothing
Next
NestedListShow itms
End Sub
Private Sub NestedListShow(ByRef itms As Dictionary)
Dim r As Long, c As Long
For r = 1 To itms.Count
For c = 1 To itms(r).Count
Debug.Print "Row " & r & ", Col " & c & ": ---> " & itms(r)(c)
Next
Next
End Sub
<小时/>
注释:
关于VBA:使用类模块/集合和/或动态数组?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44834491/
我正在尝试创建一个包含 int[][] 项的数组 即 int version0Indexes[][4] = { {1,2,3,4}, {5,6,7,8} }; int version1Indexes[
我有一个整数数组: private int array[]; 如果我还有一个名为 add 的方法,那么以下有什么区别: public void add(int value) { array[va
当您尝试在 JavaScript 中将一个数组添加到另一个数组时,它会将其转换为一个字符串。通常,当以另一种语言执行此操作时,列表会合并。 JavaScript [1, 2] + [3, 4] = "
根据我正在阅读的教程,如果您想创建一个包含 5 列和 3 行的表格来表示这样的数据... 45 4 34 99 56 3 23 99 43 2 1 1 0 43 67 ...它说你可以使用下
我通常使用 python 编写脚本/程序,但最近开始使用 JavaScript 进行编程,并且在使用数组时遇到了一些问题。 在 python 中,当我创建一个数组并使用 for x in y 时,我得
我有一个这样的数组: temp = [ 'data1', ['data1_a','data1_b'], ['data2_a','data2_b','data2_c'] ]; // 我想使用 toStr
rent_property (table name) id fullName propertyName 1 A House Name1 2 B
这个问题在这里已经有了答案: 关闭13年前。 Possible Duplicate: In C arrays why is this true? a[5] == 5[a] array[index] 和
使用 Excel 2013。经过多年的寻找和适应,我的第一篇文章。 我正在尝试将当前 App 用户(即“John Smith”)与他的电子邮件地址“jsmith@work.com”进行匹配。 使用两个
当仅在一个边距上操作时,apply 似乎不会重新组装 3D 数组。考虑: arr 1),但对我来说仍然很奇怪,如果一个函数返回一个具有尺寸的对象,那么它们基本上会被忽略。 最佳答案 这是一个不太理
我有一个包含 GPS 坐标的 MySQL 数据库。这是我检索坐标的部分 PHP 代码; $sql = "SELECT lat, lon FROM gps_data"; $stmt=$db->query
我需要找到一种方法来执行这个操作,我有一个形状数组 [批量大小, 150, 1] 代表 batch_size 整数序列,每个序列有 150 个元素长,但在每个序列中都有很多添加的零,以使所有序列具有相
我必须通过 url 中的 json 获取文本。 层次结构如下: 对象>数组>对象>数组>对象。 我想用这段代码获取文本。但是我收到错误 :org.json.JSONException: No valu
enter code here- (void)viewDidLoad { NSMutableArray *imageViewArray= [[NSMutableArray alloc] init];
知道如何对二维字符串数组执行修剪操作,例如使用 Java 流 API 进行 3x3 并将其收集回相同维度的 3x3 数组? 重点是避免使用显式的 for 循环。 当前的解决方案只是简单地执行一个 fo
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
我有来自 ASP.NET Web 服务的以下 XML 输出: 1710 1711 1712 1713
如果我有一个对象todo作为您状态的一部分,并且该对象包含数组列表,则列表内部有对象,在这些对象内部还有另一个数组listItems。如何更新数组 listItems 中 id 为“poi098”的对
我想将最大长度为 8 的 bool 数组打包成一个字节,通过网络发送它,然后将其解压回 bool 数组。已经在这里尝试了一些解决方案,但没有用。我正在使用单声道。 我制作了 BitArray,然后尝试
我们的数据库中有这个字段指示一周中的每一天的真/假标志,如下所示:'1111110' 我需要将此值转换为 boolean 数组。 为此,我编写了以下代码: char[] freqs = weekday
我是一名优秀的程序员,十分优秀!