我想将四列中的数据转换为矩阵表。我尝试过使用OFFSET功能,但是我的数据太大了(大约100,000个单元格)并且崩溃了。
所以,我想通过宏来尝试这样做,你能建议怎么做吗?或者你有更好的建议,那将是伟大的。
PS。我使用了此网站here中的OFFSET公式。
答案 0 :(得分:2)
使用以上类型的齿轮进行ROWS,柱的颜色和Σ值的总和:
隐藏顶行,报表布局以表格形式显示,删除所有小计和总计,重新排列列和行的顺序,设置为显示0
的空单元格,隐藏展开/折叠按钮,重复所有项目标签设置为*
,并添加了边框。
为了显示0
的行,我在源数据中添加了Bus / Green / Manual(颜色(绿色)以避免(空白)作为额外列)。
*
在Excel 2007中不可用。要重复Excel 2010之前版本的项目标签,标准做法是复制PT和选择性粘贴,使用Go To Special,Blanks选择空白并填充空白然后=
,向上, Ctrl + 输入。
答案 1 :(得分:0)
有趣的问题!因为您遇到涉及数据大小的问题,所以我试图避免使用字典之类的对象(我不知道字典可以容纳多少)。相反,我创建了一个程序,可以跟踪非常少的数据,但最终会不断地从文件读取/写入:它会非常慢,但它适用于非常大的文件。
无论如何,请尝试将以下代码复制并粘贴到VBA模块中,然后在您的文件上运行它。您可能需要更改行和列的某些值。
编辑:我为你给出的示例图片工作了,但它很乱。我明天会试着让它更清楚(g2g)摘要
例:
代码:( SO摆脱了空白:(我认为我的帖子太长了)
'Start and end row of the original data
Private dataStartRow As Long
Private dataEndRow As Long
'The start row/column of the matrix
Private matrixStartRow As Long
Private matrixStartCol As Long
'How many rows/columns in the matrix
Private matrixRowLength As Long
Private matrixColLength As Integer
Public Sub makeMatrixTable()
'Sets initial values for variables
initializeValues
'Builds table
buildTable
End Sub
Private Function initializeValues()
'The actual data probably begins on row 2, because row 1 is usually used for column titles
dataStartRow = 2
'Get last row of data
dataEndRow = ActiveSheet.UsedRange.Rows.Count
'By adding 2, we create a gap row between our new matrix table and the original data table
matrixStartRow = dataEndRow + 2
'The matrix values begin after column 2, because columns 1&2 are used for titles
matrixStartCol = 2
matrixRowLength = 0
matrixColLength = 0
End Function
Private Function buildTable()
Dim dataRow As Long
Dim matrixRow As Long
Dim matrixCol As Integer
Dim value As String
'The keys are the column/row titles
'I'm using the work "key" because we're mimicking a dictionary object by only using a key once
'in this case it's a little more complicated, as we have 3 keys (2 row keys, 1 column key)
Dim rowKey1 As String, rowKey2 As String
Dim colKey As String
'loop through all rows containing data
For dataRow = dataStartRow To dataEndRow
'get keys from data
rowKey1 = CStr(ActiveSheet.Cells(dataRow, 1).value)
rowKey2 = CStr(ActiveSheet.Cells(dataRow, 3).value)
colKey = CStr(ActiveSheet.Cells(dataRow, 2).value)
'find if we have already created rows for the row keys, and if so return the row (else -1)
matrixRow = rowExistsInMatrix(rowKey1, rowKey2)
'find if we have already created a column for the column key, and if so return the row (else -1
matrixCol = colExistsInMatrix(colKey)
'Our matrix does not have a row with those row keys, so we must create one
If matrixRow = -1 Then
'increase the size of our matrix
matrixRowLength = matrixRowLength + 1
'get row that is not in use
matrixRow = matrixStartRow + matrixRowLength
'add the new keys to matrix
ActiveSheet.Cells(matrixRow, 1).value = rowKey1
ActiveSheet.Cells(matrixRow, 2).value = rowKey2
End If
'We don't have a column that matches the column key
If matrixCol = -1 Then
'increase size of matrix table
matrixColLength = matrixColLength + 1
'get column that is not in use
matrixCol = matrixStartCol + matrixColLength
'add new key to matrix
ActiveSheet.Cells(matrixStartRow, matrixCol).value = colKey
End If
'get the value to be placed in the matrix from column 4
value = CStr(ActiveSheet.Cells(dataRow, 4).value)
'place value
ActiveSheet.Cells(matrixRow, matrixCol).value = value
Next dataRow
End Function
'Checks to see if the key from the data table exists in our matrix table
'if it does, return the row in the matrix table
'else return -1
Private Function rowExistsInMatrix(dataKey1 As String, dataKey2 As String) As Long
Dim matrixRow As Long
Dim matrixKey1 As String, matrixKey2 As String
'loop through rows of matrix
For matrixRow = matrixStartRow To matrixStartRow + matrixRowLength
'get keys from matrix
matrixKey1 = CStr(ActiveSheet.Cells(matrixRow, 1).value)
matrixKey2 = CStr(ActiveSheet.Cells(matrixRow, 2).value)
'do the keys match
If dataKey1 = matrixKey1 And dataKey2 = matrixKey2 Then
rowExistsInMatrix = matrixRow
Exit Function
End If
Next matrixRow
rowExistsInMatrix = -1
End Function
'Same as rowExistsInMatrix but loops through column titles
Private Function colExistsInMatrix(dataKey As String) As Long
Dim matrixKey As String
Dim matrixCol As Integer
'loop through columns
For matrixCol = matrixStartCol To matrixStartCol + matrixColLength
matrixKey = CStr(ActiveSheet.Cells(matrixStartRow, matrixCol).value)
'does a key match
If matrixKey = dataKey Then
colExistsInMatrix = matrixCol
Exit Function
End If
Next matrixCol
colExistsInMatrix = -1
End Function