gpt4 book ai didi

asp.net - 向现有 Excel 表添加新行时,图表不会更新(必须使用命名范围)

转载 作者:行者123 更新时间:2023-12-02 16:36:51 26 4
gpt4 key购买 nike

我对 closeXMl 和 Excel 的使用也很陌生(至少对于这个目的),如果我问了愚蠢的问题,我很抱歉。

我知道 ClosedXML 还不支持图表,所以想到解决这个问题的唯一方法是使用 excel table 创建我的图表。 。这样,我认为 ClosedXML 会在我插入新行时更新范围,并且图表会拾取它。嗯,事实并非如此。至少当我使用 closeXML 库从代码添加行时不会。

令人好奇的是,从 Excel 内部添加新行会自动更新图表,但如果我想从代码中获得相同的结果,我必须使用 OFFSET 公式和命名范围,然后将图表源数据设置为这些命名范围范围。这就是为什么我想知道我用来插入新行的代码是否有问题:

    Dim ruta As String = Server.MapPath("~/Templates/MyTemplate.xlsx")
Dim wb As New XLWorkbook(ruta)
Dim ws = wb.Worksheet(1)

Dim tblData = ws.Table("Table1")

Dim year As Integer = 2000
For i As Integer = 1 To 13

With tblData.DataRange.LastRow()
.Field("Year").SetValue(year)
.Field("Sales").SetValue(CInt(Math.Floor((2000 - 500 + 1) * Rnd())) + 500)
End With
tblData.DataRange.InsertRowsBelow(1)
year = year + 1
Next

tblData.LastRow.Delete()

正如您所看到的,代码非常简单,模板也非常简单,仅包含两列:“年份”(table1[Year]) 和 “销售额” (表1[销售额]

我认为这与我的模板没有任何关系,因为正如我告诉你的那样,直接从 Excel 添加新行可以按预期工作,并且只有当我从图表系列不包含的代码生成表格时添加的新行 enter image description here

需要手动添加新范围(Sheet1!Table1[Sales]Sheet1!Table1[Year]),因为它仅包含第一行(第一行)插入表格时默认添加) enter image description here

任何帮助将不胜感激

附注这是link包含完整代码和 Excel 模板的 rar (\Templates\MyTemplate.xlsx)

最佳答案

如果问题是您的表无法识别其他行,请尝试在最后一行删除后添加此行:

tblData.Resize tblData.Range(1, 1).CurrentRegion

这应该调整表格的大小。那么希望您的表操作应该能够正常工作。

关于asp.net - 向现有 Excel 表添加新行时,图表不会更新(必须使用命名范围),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13958809/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com