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 }
Form的调用的方法如下:
以上是关于C# winform DevExpress GridControl 大批量数据(9万行+4百列)导出Excel报错,内存溢出,怎么办?的主要内容,如果未能解决你的问题,请参考以下文章
C# winform DevExpress GridControl 大批量数据(9万行+4百列)导出Excel报错,内存溢出,怎么办?
求助,c# WinForm Chart控件中 一个x轴,多个y轴 如图所示,应该怎样实现。