.net - 数据透视缓存类型不匹配错误 VB.NET Excel

标签 .net vb.net excel pivot-table

请参阅底部编辑了解我目前所处的位置,谢谢。

我创建了一个数据透视表,当数据透视缓存定义为:

        Dim ptCache As Excel.PivotCache = mainHighway.PivotCaches.Add(SourceType:=Excel.XlPivotTableSourceType.xlDatabase, SourceData:=mainHighwayData.Range("a1:v7500"))

我的问题是行数每天都在变化,所以我找出工作表中的行数,然后在我的数据透视缓存中使用它:
Dim highlRow As Integer
highlRow = mainHighwayData.Cells.SpecialCells(XlCellType.xlCellTypeLastCell).Row
Dim ptCache As Excel.PivotCache = mainHighway.PivotCaches.Add(SourceType:=Excel.XlPivotTableSourceType.xlDatabase, SourceData:=mainHighwayData.Range("a1:V" & highlRow))

从历史上看,这个解决方案对我来说效果很好,但是当我在这里这样做时,我得到:
Type mismatch. (Exception from HRESULT: 0x80020005 (DISP_E_TYPEMISMATCH))

我一直在摆弄它,发现如果我这样做:
highlRow = 7000
Dim ptCache As Excel.PivotCache = mainHighway.PivotCaches.Add(SourceType:=Excel.XlPivotTableSourceType.xlDatabase, SourceData:=mainHighwayData.Range("a1:V" & highlRow))

它工作正常,所以我想知道如何使用 specialcells 命令定义 highlRow 并将其存储为整数有什么问题。我觉得这里有某种类型或类型转换问题,但我无法解决。我试过了:
highlRow = CType(mainHighwayData.Cells.SpecialCells(XlCellType.xlCellTypeLastCell).Row, Integer)

这也不好。也许我找到最后一行的方法在这里不适用?无论如何,我已经花了很长时间修补它,此时我只是在转动我的轮子。如果您有任何想法,将不胜感激。

一如既往地谢谢你。

编辑:我也试过:
UsedRange.Rows.Count

这在历史上一直有效,但也无法运行。在这一点上,我很好奇为什么枢轴缓存似乎特别有这个问题。

@charles 有一个好主意,可以尝试其他方法来获取最后一个单元格。我试过了:
highlRow = mainHighwayData.Range("A65535").End(XlDirection.xlUp).Row

我让它给出正确的行,但它仍然抛出类型不匹配错误。
highlRow = mainHighwayData.Cells.Find("*", SearchOrder:=Excel.XlSearchOrder.xlByRows, SearchDirection:=XlSearchDirection.xlPrevious).Row

这将返回最后一行的正确数字,但再次引发相同的类型不匹配错误。

编辑:我发现了另一点信息,但我不确定如何处理它。如果数据透视表中的值 <= 65536,则数据透视表工作正常,但第二次我将范围增加到 65537,我得到了一直困扰我的类型不匹配。对于所有 >= 65537 的数字都是如此。我知道 65535 左右曾经是 excel 中的最后一行,但现在已经不是这样了。此外,当我在 excel 中手动创建数据透视表时,我没有遇到任何问题,并且它包含所有数据。我使用的是 int 或 long,所以它不应该是溢出或任何东西。有人对为什么 VB.NET 不允许我根据超过 65537 行的数据制作数据透视表有任何想法吗?

最佳答案

好吧,这有点像一场噩梦,但我找到了一个有效的修复方法。我注意到 vba 中的人也有同样的问题,他们正在切换到 r1c1 表示法,但我也无法让它工作,但我发现了这个 post并且对那里的答案的最后评论有解决方案。

highlRow = mainHighwayData.Range("A500000").End(XlDirection.xlUp).Row
Dim rng As Excel.Range
rng = mainHighwayData.Range("A1:Q" & highlRow)
mainHighway.Names.Add(Name:="Range1", RefersTo:=rng)
Dim ptCache As Excel.PivotCache = mainHighway.PivotCaches.Add(SourceType:=Excel.XlPivotTableSourceType.xlDatabase, SourceData:="Range1")

因此,您创建了一个命名范围,然后引用它。我想这个想法是你需要从简单的范围对象中抽象出来,这将允许你制作你的数据透视表。

关于.net - 数据透视缓存类型不匹配错误 VB.NET Excel,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10423071/

相关文章:

c# - 通用 lambda 方法签名

VB.NET Combobox - 数值的自动完成行为

Excel VBA 存储/暗表标签颜色

c# - 读取对象属性时忽略 NullReferenceException

c# - 多步 OLE DB 操作产生错误。检查每个 OLE DB 状态值(如果可用)。没有完成任何工作

.net - 使用 DeviceWatcher 监控 USB 驱动器并检索设备信息?

c# - 方法参数的 ref、val 和 out 是什么意思?

python - 使用pandas python将带有sheet2中出现次数的关键字添加到sheet1中的现有excel文件中

excel - 如何垂直和水平合并或合并具有相同值的单元格,Excel VBA?

.net - 低速网络,断线风险高