以文本方式查看主题 - Foxtable(狐表) (http://foxtable.com/bbs/index.asp) -- 专家坐堂 (http://foxtable.com/bbs/list.asp?boardid=2) ---- excel模板导出数据多,程序闪退 (http://foxtable.com/bbs/dispbbs.asp?boardid=2&id=192389) |
-- 作者:hellfirellb -- 发布时间:2024/6/20 16:07:00 -- excel模板导出数据多,程序闪退 book.AddDataTable("客户对账",sqlstr) book.AddDataTable("客户对账明细",dt) book.AddRelation("客户对账","对账编号","客户对账明细","对账编号") Book.Build() 明细表大概2千多条数据,生成过程中程序闪退,是数据量多的问题么?有什么解决办法么? |
-- 作者:有点蓝 -- 发布时间:2024/6/20 16:19:00 -- 2千多条不算多,一般闪退是出现了死循环 |
-- 作者:hellfirellb -- 发布时间:2024/6/20 16:32:00 -- 我觉得也不应该,但我是用模板导出,数据都加载了,就是build过程闪退,就是上面的主要代码,怎么会死循环呢 |
-- 作者:有点蓝 -- 发布时间:2024/6/20 16:34:00 -- 完整代码发上来看看 |
-- 作者:hellfirellb -- 发布时间:2024/6/20 16:49:00 -- Dim dt As DataTable dt = ExecSQLGetDataTable(sql1,"V16Data") \'MessageBox.show(dt.DataRows.Count) Dim Book As New XLS.Book(fp) Dim dlg As New SaveFileDialog \'定义一个新的SaveFileDialog dlg.Filter= "Excel文件|*.xls" \'设置筛选器 dlg.FileName=tr("客户简称") & tr("对账年份") & tr("对账月份") & "对账表.xlsx" If dlg.ShowDialog = DialogResult.Ok Then \'如果用户单击了确定按钮 Dim fl As String = dlg.FileName book.AddDataTable("客户对账","V16Data",sqlstr) book.AddDataTable("客户对账明细",dt) book.AddRelation("客户对账","对账编号","客户对账明细","对账编号") \'建立关联 \'MessageBox.show("start build") Book.Build() \'生成细节区 Book.Save(fl) \'保存工作簿 \'MessageBox.Show("end") Dim Proc As New Process \'打开工作簿 Proc.File = fl Proc.Start() End If 测试了800多条数据正常,很奇怪(有sql语句的地方发不出来,改成变量了)。
|
-- 作者:有点蓝 -- 发布时间:2024/6/20 17:14:00 -- 这样试试 Dim Book As New XLS.Book(fp) Dim dlg As New SaveFileDialog \'定义一个新的SaveFileDialog dlg.Filter= "Excel文件|*.xls" \'设置筛选器 dlg.FileName=tr("客户简称") & tr("对账年份") & tr("对账月份") & "对账表.xlsx" If dlg.ShowDialog = DialogResult.Ok Then \'如果用户单击了确定按钮 Dim fl As String = dlg.FileName book.AddDataTable("客户对账","V16Data",sqlstr) book.AddDataTable("客户对账明细","V16Data",sql1) book.AddRelation("客户对账","对账编号","客户对账明细","对账编号") \'建立关联 \'MessageBox.show("start build") Book.Build() \'生成细节区 Book.Save(fl) \'保存工作簿 \'MessageBox.Show("end") Dim Proc As New Process \'打开工作簿 Proc.File = fl Proc.Start() End If |
-- 作者:hellfirellb -- 发布时间:2024/6/23 19:21:00 -- 蓝老大,按你那个代码不行,其实原来就是你这种写法,不行才换的,还是闪退。还麻烦您看一下怎么解决比较好 |
-- 作者:hellfirellb -- 发布时间:2024/6/23 20:16:00 -- 解决了,蓝老大,客户做的模板下面有多余的行,有异常。晕死 |