C# winform DevExpress GridControl 大批量数据(9万行+4百列)导出Excel报错,内存溢出,怎么办?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C# winform DevExpress GridControl 大批量数据(9万行+4百列)导出Excel报错,内存溢出,怎么办?相关的知识,希望对你有一定的参考价值。

我导出excel的代码如图: 执行小批量的(几十条)没问题,但是这次突然遇到大批量数据(9万行+4百列),我导出的是Xlsx格式,导数据过程中会出现内存溢出,怎么办,求大佬指教

数据太多了,估计你只能换其他Excel导出的库了,比如NPOI

官方支持上有说明,如果Cell数小于1000000还可以试试

追问

Cell数是指单元格数吗,那我这个90000*400,应该过了

追答

对,单元格

追问

我这个超过过了,稳稳的

参考技术A 换个库导出试过吗 npoi追问

没用过这个东西,难受

追答

项目可以给我调试调试吗

追问

我导出的excel的代码就在图片里,你可以直接通过看图识字把字复制出来就可以用了,项目因为是公司的,所以不方便给你,不好意思啊,你可以直接用图中的代码

追答

npoi库吧,稍微学习下就可以用了

c# winForm 等待窗体的实现

最近在做一个项目,需要用到等待窗体,在DevExpress下面有SplashScreen控件可以使用,同时也有ProgressIndicator控件能用,但是如果没有用Dev开发的话,我们就需要自定义一个等待窗体了。

 

首先,把截图放上来:

技术分享

实现的功能比较简单,就是在程序处理 一些耗时比较多的代码时,将Loading窗体展示给用户,并在后台进行执行。

 

这个程序,参考了 网名为 “八哥” 的一个程序,当时我在群里面的时候,感谢他的热情帮助。

现将我的代码贴出来吧,里面用的了委托的概念。大家如果不懂的话,可以百度一下,这里给出几个链接:

http://blog.csdn.net/ggz631047367/article/details/44646233

http://www.runoob.com/csharp/csharp-delegate.html

http://blog.csdn.net/sjj2011/article/details/7835200

http://blog.csdn.net/testcs_dn/article/details/37671513

技术分享

LoadingControl.cs代码如下:

技术分享
  1 using System;
  2 using System.Collections.Generic;
  3 using System.ComponentModel;
  4 using System.Data;
  5 using System.Drawing;
  6 using System.Linq;
  7 using System.Text;
  8 using System.Windows.Forms;
  9 using System.Threading;
 10 
 11 namespace ControlToolsLibrary
 12 {
 13     public partial class LoadingControl : Form
 14     {
 15 
 16         public delegate void mydelegate();
 17         public mydelegate eventMethod;
 18         private static LoadingControl pLoading = new LoadingControl();
 19         delegate void SetTextCallback(string title,string caption,string description);
 20         delegate void CloseFormCallback();
 21         public LoadingControl()
 22         {
 23             InitializeComponent();
 24             initLoadintForm();
 25             Thread t = new Thread(new ThreadStart(delegateEventMethod));
 26             t.IsBackground = true;
 27             t.Start();
 28         }
 29 
 30         private void LoadingControl_FormClosing(object sender, FormClosingEventArgs e)
 31         {
 32             if (!this.IsDisposed)
 33             {
 34                 this.Dispose(true);
 35             }
 36         }
 37 
 38         private void initLoadintForm() {
 39             this.ControlBox = false;   // 设置不出现关闭按钮
 40             this.StartPosition = FormStartPosition.CenterParent;
 41         }
 42 
 43         private void delegateEventMethod()
 44         {
 45             eventMethod();
 46         }
 47 
 48         public static LoadingControl getLoading()
 49         {
 50             if (pLoading.IsDisposed)
 51             {
 52                 pLoading = new LoadingControl();
 53                 return pLoading;
 54             }
 55             else
 56             {
 57                 return pLoading;
 58             }
 59         }
 60 
 61         //这种方法演示如何在线程安全的模式下调用Windows窗体上的控件。  
 62         /// <summary>
 63         /// 设置Loading 窗体的 标题title,标签 caption 和描述 description
 64         /// </summary>
 65         /// <param name="title">窗口的标题[为空时,取默认值]</param>
 66         /// <param name="caption">标签(例如:please wait)[为空时,取默认值]</param>
 67         /// <param name="description">描述(例如:正在加载资源...)[为空时,取默认值]</param>
 68         public void SetCaptionAndDescription(string title,string caption, string description)
 69         {
 70             if (this.InvokeRequired&&LoadingControl.lbl_caption.InvokeRequired && LoadingControl.lbl_description.InvokeRequired)
 71             {
 72                 SetTextCallback d = new SetTextCallback(SetCaptionAndDescription);
 73                 this.Invoke(d, new object[] { title,caption, description });
 74             }
 75             else
 76             {
 77                 if (!title.Equals("")) {
 78                     this.Text = title;
 79                 }
 80                 if (!caption.Equals(""))
 81                 {
 82                     LoadingControl.lbl_caption.Text = caption;
 83                 }
 84                 if (!description.Equals("")) {
 85                     LoadingControl.lbl_description.Text = description;
 86                 }
 87             }
 88         }
 89 
 90         public  void CloseLoadingForm()
 91         {
 92             if (this.InvokeRequired)
 93             {
 94                 CloseFormCallback d = new CloseFormCallback(CloseLoadingForm);
 95                 this.Invoke(d, new object[] {  });
 96             }
 97             else
 98             {
 99                 if (!this.IsDisposed)
100                 {
101                     this.Dispose(true);
102                 }
103             }
104         }
105 
106         public void SetExecuteMethod(mydelegate method)
107         {
108               this.eventMethod += method;
109         }
110 
111 
112     }
113 }
View Code

Form的调用的方法如下:

技术分享

 

以上是关于C# winform DevExpress GridControl 大批量数据(9万行+4百列)导出Excel报错,内存溢出,怎么办?的主要内容,如果未能解决你的问题,请参考以下文章

C# winform DevExpress GridControl 大批量数据(9万行+4百列)导出Excel报错,内存溢出,怎么办?

winform dev的GridView双击事件怎么实现

求助,c# WinForm Chart控件中 一个x轴,多个y轴 如图所示,应该怎样实现。

c#中第三方控件问题

c# devexpress 中的Gridcontrol 添加行问题

C# WinForm开发 需要一个类似office 2007 菜单栏的控件