背景:

在北京工作的时候,又一次同事问了我这样一个问题,说我要把从数据库获取到的数据直接通过NPOI进行导出,但是我对导出的格式要特殊的要求,如图:

冥思苦想,最终顺利帮同事解决问题,虽然有点瑕疵,但是毕竟是盲写,也算是圆满完成任务了:

//假设 DataTable dt=获取到的datatable
List<Year_Month> listYear=Year_Month.ToList();//年限list
List<Data> dataList=Data.ToList();//国别list
List<dt> dtList=dt.ToList();//数据list int countYear=listYear.Count();//年限数量
int countdata=dataList.Count();//国别数量
int countdt=dtList.Count();//数据数量 row=sheet.CreateRow(0);//创建行
cell=row.CreateCell(0);//创建列
cell.SetCellValue("时间");//单元格赋值
//合并行,合并列
sheet.AddMergedRegion(new CellRangeAddress(0,2,0,0));//些数据头,时间 //标题进出口岸
cell=row.CreateCell(1);//创建列
cell.SetCellValue("进出口岸");//单元格赋值
//合并行,合并列
sheet.AddMergedRegion(new CellRangeAddress(0,0,1,countdata*2));//进出口岸 //进口口岸名称
row=sheet.CreateRow(1);
for(int i=0;i<dataList.count;i++)
{
//根据数据条数,动态创建列
cell=row.CreateCell(2*i+1);
//合并行,合并列
sheet.AddMergedRegion(new CellRangeAddress(1,1,2*i+1,2*(i+1)));//进出口岸
//批量赋值
cell.SetCellValue(dataList[i].GuoName);
} //进出口
row=sheet.CreateRow(2);
for(int i=0;i<dataList.count;i++)
{
cell=row.CreateCell(2*i+1);
cell.SetCellValue("进口");
cell=row.CreateCell(2*i+2);
cell.SetCellValue("出口");
} //数据
for(int i=0;i<yearList.count;i++)
{
row=sheet.CreateRow(i+3);//年份
cell=row.CreateCell(0);
cell.SetCellValue(yearList[i].nian); //数据赋值
for(int j=0;j<datalist.count;j++)
{
var item=shujuzongtiaoshu.where(u=>u.nianfen==yearList[i].year).toList();
for(int k=0;k<item.count;k++)
{
//数据有值赋值,没有的值得赋空值单元格站位
if(item[k].guobiemingcheng==dataList[j].name)
{
cell=row.CreateCell(2*j+1);
cell.SetCellValue(datalist[j].jinkou);
cell=row.CreateCell(2*j+2);
cell.SetCellValue(datalist[j].chukou);
}else
{
cell=row.CreateCell(2*j+1);
cell.SetCellValue("");
cell=row.CreateCell(2*j+2);
cell.SetCellValue("");
}
}
}
}

效果:

提示:图片纯属后来补充,不能代表正式环境下生成文档格式,请见谅

总结:

技术什么的只要肯下功夫都会有的,面包会有的,奶油也会有的。可是难能可贵的是我们在不知道怎么做的时候能坚持一下,去自己脑补,我们要对自己,对生活乃至对工作任务及实现方法充满幻想与想象,只有这样,我们才有取之不竭用之不尽的创新去支持我们,给自己加油!

Excel动态合并行、合并列的更多相关文章

  1. Reapter合并行

    html文件: <asp:Repeater ID="rptEmployee" runat="server"> <HeaderTemplate& ...

  2. Vim常用操作-合并行。

    刚接触 Vim 会觉得它的学习曲线非常陡峭,要记住很多命令.所以这个系列的分享,不会教你怎么配置它,而是教你怎么快速的使用它. 在开发时为了代码美观,经常会把属性用换行的方式显示. <el-di ...

  3. easyui生成合并行,合计计算价格

    easyui生成合并行,合计计算价格 注:本文来源: 原创 一:图样你效果图 二:代码实现 1:datagrid 列展示: window.dataGrid = $("#dataGrid&qu ...

  4. sed行处理详解(交换行,合并行,删除行等)

    1.合并行 zj@zj:~/Script/blog_script$ cat test11234合并上下两行zj@zj:~/Script/blog_script$ sed '$!N;s/\n/\t/' ...

  5. 【editplus经常用的快捷键】Editplus 选中一行ctrl+r,Edit 合并行 Ctrl+Shift+J 合并选定行 删除当前行

    Editplus 选中一行: ctrl+rEditplus 复制一行: ctrl+r选择行,然后ctrl+c复制.复制一行到下一行中:Editplus有:Ctrl+j 复制上一行的一个字符到当前行Ed ...

  6. C# 如何在Excel 动态生成PivotTable

    Excel 中的透视表对于数据分析来说,非常的方便,而且很多业务人员对于Excel的操作也是非常熟悉的,因此用Excel作为分析数据的界面,不失为一种很好的选择.那么如何用C#从数据库中抓取数据,并在 ...

  7. LaTex 制作表格 合并行\multirow 合并列\multicolumn

    在latex文件最前面用这个包\usepackage{multirow} multirow 宏包提供了 \multirow 命令可以在表格中排版横跨两行以上的文本.命令的格式如下: \multirow ...

  8. js【table】合并行,合并列

    eg: function hbh() { var tab = document.getElementById("tableID"); var maxCol = 2, val, co ...

  9. 【EXCEL】簡単に合計をとる方法

    下記のような表があるとして.合計を取るときみんなSUM関数を使用しています. その方法もよいですが.もっと簡単の方法を説明します. ①合計する部分を選択します. ②ALT+=を押します. ※ノートパソ ...

随机推荐

  1. 手记-数学分析(高等数学)中有关算法效率的公式列举(O,Θ,Ω)

      权当数据结构与算法分析的学习手记     系数为一的幂级数部分和公式 ∑ n2 = 12 + 22 + 32 + ... + n2 = n(n+1)(2n+1)/6 = O(n3) ∑ n3 =  ...

  2. Linux实时流量监控工具 - iftop

    *本文转自ggjucheng的博客 介绍 iftop是一款实时流量监控工具,监控TCP/IP连接等,缺点就是无报表功能.必须以root身份才能运行. 实例 默认是监控第一块网卡的流量 iftop 监控 ...

  3. metro压缩和解压文件

    在1.zip中增加一张新图片StorageFile jpg = await KnownFolders.PicturesLibrary.GetFileAsync("1.jpg"); ...

  4. ASM:《X86汇编语言-从实模式到保护模式》第七章应用例:用adc命令计算1到1000的累加

    在16位的处理器上,做加法的指令是add,但是他每次只能做8位或者16位的加法,除此之外,还有一个带进位的加法指令adc(Add With Carry),他的指令格式和add一样,目的操作数可以是8位 ...

  5. java获取本月或某月的第一天和最后一天

    获取某月的第一天和最后一天的日期 Calendar calendar = Calendar.getInstance(); calendar.setTime(date); calendar.set(Ca ...

  6. BestCoder36 1002.Gunner 解题报告

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5199 题目意思:给出鸟在树上的高度,以及射击到的高度,问每次射击能射中鸟的数量 用 vector 里面 ...

  7. C#中XmlTextWriter读写xml文件详细介绍(转)

    转自http://www.jb51.net/article/35230.htm   .NET中包含了很多支持XML的类,这些类使得程序员使用XML编程就如同理解XML文件一样简单.在这篇文章中,我将给 ...

  8. EF的各种删除方法

    //2.1检查 id 是否存在 //2.2执行删除 Models.Student stu = new Models.Student() { Id = id }; //db.Students.Attac ...

  9. Html5 新标签

    ⒈ <audio></audio> 定义声音<autoplay></autoplay> 该属性出现,音频就绪后马上播放<controls>& ...

  10. yii过滤器的原理和使用

    过滤器官方页面:http://www.yiiframework.com/doc/guide/1.1/zh_cn/basics.controller 过滤器是一段代码,可被配置在控制器动作执行之前或之后 ...