接上文NPOI大数据分批写入同个Excel,这次是利用task多任务同时写入到多个Excel。

Form2.cs

    private void btnExport_Click(object sender, EventArgs e)
{
try
{
txtSql.SafeCall(() =>
{
txtSql.AppendText("开始处理...\r\n");
}); string sqlCount = Sql.GetRecordSql(GetBusinessType(), "");
recordCount = db.ExecuteScalar(sqlCount);
rowIndex = 0; string[] sqlWhereArray = Sql.SqlWhereArray;
TaskFactory taskFactory = new TaskFactory();
Task[] tasks = new Task[sqlWhereArray.Length];
for (int k = 0; k < sqlWhereArray.Length; k++)
{
string sqlWhere = sqlWhereArray[k];
int sqlIndex = k; tasks[sqlIndex] = new Task(Export, sqlIndex);
tasks[sqlIndex].Start();
}
taskFactory.ContinueWhenAll(tasks, TaskEnded, TaskContinuationOptions.None); }
catch (Exception ex)
{
MessageBox.Show("发生异常,错误提示:" + ex.Message);
}
} private void Export(object state)
{
BusinessType businessType = GetBusinessType();
string[] DateRemarkArray = Sql.DateRemarkArray;
string sql = "";
string sqlWhere = "";
int sqlIndex = (int)state;
DataTable dt = null;
lock (moniter)
{
sqlIndex = (int)state;
sqlWhere = Sql.SqlWhereArray[sqlIndex];
sql = Sql.GetDataSql(businessType, sqlWhere);
dt = db.GetDataSet(sql).Tables[0];
} IWorkbook workbook = new XSSFWorkbook();
ISheet sheet = workbook.CreateSheet();
txtSql.SafeCall(() =>
{
txtSql.AppendText("条件" + (sqlIndex + 1).ToString() + ":" + DateRemarkArray[sqlIndex] + "\r\n");
}); IRow row0 = sheet.CreateRow(0);
for (int m = 0; m < dt.Columns.Count; m++)
{
DataColumn dc = dt.Columns[m];
row0.CreateCell(m).SetCellValue(dc.ColumnName);
} for (int i = 0; i < dt.Rows.Count; i++)
{
System.Threading.Interlocked.Increment(ref rowIndex); DataRow dr = dt.Rows[i];
IRow row = sheet.CreateRow(i+1);
for (int j = 0; j < dt.Columns.Count; j++)
{
row.CreateCell(j).SetCellValue(dr[j].ToString());
} Label lbl = GetLabel(sqlIndex + 1);
lbl.SafeCall(() =>
{
if (i == (dt.Rows.Count - 1))
{
txtSql.AppendText("条件" + (sqlIndex + 1).ToString() + "完成,行数:" + (i + 1).ToString() + "\r\n");
lbl.Text = "条件" + (sqlIndex + 1).ToString() + "完成";
}
else
{
lbl.Text = string.Format("正在导出第{0}个条件,第{1}行", (sqlIndex + 1).ToString(), (i + 1).ToString());
}
double x = rowIndex * 1.0 / recordCount * 100;
lblProgress.Text = string.Format("总行数:{0}, 当前完成总{1}行,百分占比:{2} %", recordCount.ToString(), rowIndex.ToString(), x.ToString("#0.0"));
});
}
string fileName = string.Format("{0}_{1}.xlsx", businessType.ToString(), DateRemarkArray[sqlIndex]);
FileStream outFs = new FileStream(fileName, FileMode.Create);
workbook.Write(outFs);
outFs.Close();
}

NPOI利用多任务模式分批写入多个Excel的更多相关文章

  1. NPOI大数据分批写入同个Excel

    实现过程: 要导出来的数据库数据量很大,一次取出来压力有点大,故分批取出来,导入到同一个Excel. 因为Excel2003版最大行数是65536行,Excel2007开始的版本最大行数是104857 ...

  2. 将如下三组不同类型的数据利用DataInputStream和DataOutputStream写入文件,然后从文件中读出

    三组数据如下: {19.99 , 9.99 , 15.99 , 3.99 , 4.99} {12 , 8 , 13 ,29 ,50} {"Java T-shirt" , " ...

  3. 利用工厂模式实现serviec层和dao层解耦

    利用工厂模式实现serveice和dao层的解耦,这样就可以不用在service层实例化dao层的对象,当dao层代码发生改变的时候(数据库实现发生改变)直接修改配置文件就不用改变service层的代 ...

  4. 利用mvc模式,实现用户的注册

    实现功能:利用mvc模式,实现用户的登陆注册功能 1.程序的框架结构 2个包,bean,以及servlet 3个jsp页面,注册页面,注册成功页面,注册失败页面 mysql驱动 2.编程思想 通过js ...

  5. [Office][C#] NPOI、OpenXML SDK、OpenOffice.org SDK 写入资料到 EXCEL 档案[转]

    原文地址:http://www.dotblogs.com.tw/chou/archive/2010/04/29/14912.aspx 一.簡介 要將資料寫入 EXCEL 檔案有許多的方法,但假如電腦不 ...

  6. C#中创建、打开、读取、写入、保存Excel的一般性代码

    ---转载:http://hi.baidu.com/zhaocbo/item/e840bcf941932d15fe358228 1. Excel对象微软的Excel对象模型包括了128个不同的对象,从 ...

  7. SQLBulkCopy使用实例--读取Excel写入数据库/将 Excel 文件转成 DataTable

    MS SQL Server 提供一个称为 bcp 的流行的命令提示符实用工具,用于将数据从一个表移动到另一个表(表可以在不同服务器上). SqlBulkCopy 类允许编写提供类似功能的托管代码解决方 ...

  8. python3爬取”理财大视野”中的股票,并分别写入txt、excel和mysql

    需求:爬取“理财大视野”网站的排名.代码.名称.市净率.市盈率等信息,并分别写入txt.excel和mysql 环境:python3.6.5 网站:http://www.dashiyetouzi.co ...

  9. Python常见问题 - 写入数据到 excel 报 ValueError: invalid literal for int() with base 10 错误

    背景 在上写入数据到excel中,报了以下错误 出现原因 对于写入excel场景下出现该错误的话,很大概率是写入数据的单元格原本的数据格式有问题 解决方法 清理掉单元格的旧数据,然后再写入就可以了

随机推荐

  1. Android上传头像代码,相机,相册,裁剪

    activity_main.xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout ...

  2. 鸟哥的linux私房菜学习记录之档案与目录管理

    绝对路径和相对路径 绝对路径就是从根目录到某个目录下的路径,从根目录写起,也就是/ 相对路径就是从用户当前目录的路径写起 目录相关操作 cd 切换路径 例如:cd /var/www 切换到/var/w ...

  3. 编写更少bug的程序的六条准则

          如何编写更少bug的程序?  尽可能避免常见的程序错误.              沟通设计先行 + 编写可复用代码 + 做得更多 + 做的更少 + 创造“编程心流”+ 严格的程序测试   ...

  4. oracle SGA详解

    SGA(System Global Area)系统全局区.这是一个非常庞大的内存区间,也是为什么开启oracle之后占用了很大内存的原因. SGA分为不同的池,我们可以通过视图v$sgastat查看, ...

  5. Redis 转

    Redis 简介 Redis实践 Redis命令总结

  6. jython学习笔记3

    1.os.environ["HOME"] 为什么这句话在我的STS中打印不出东西,还报错 Method Description close() Close file fileno( ...

  7. MySQL与SQL比较有那些区别呢

    MySQL是一个逐渐完善的过程,使用前期版本时会遇到一些问题,通常搞得莫名其妙,在版本选择上尽量选择最新的. 1.在5.03以前版本中,存储varchar型数据时,后面的空格会被忽视掉,前面的空格会保 ...

  8. yii2通过foreach循环遍历在一个用户组中取出id去另一表里查寻信息并且带着信息合并原数组信息---案例

    yii2通过foreach循环遍历在一个用户组中取出id去另一表里查寻信息并且带着信息合并元数组信息---案例 public function actionRandomLists(){ //查询到了所 ...

  9. c# 小练习

    double a = double.Parse( this.textBox1.Text); double b = double.Parse(this.textBox2.Text); double c ...

  10. oneThink安装出错解决

    在Wampserver3.0.0(apache2.4.17+php5.6.15+mysql5.7.9)版本中oneThink安装用1.1github版,不要用1.1开发版,不然安装的时候数据库导入时b ...