因为项目中要用到服务器端创建EXCEL模板 无法直接调用EXCEL 查了下发现NPOI很方便很简单就实现了

其中走了点弯路 第一次弄的时候发现输出的值是文本不是数字型无法直接计算公式 然后又发现打开报表公式没有自动计算 后来都解决了 详见代码

 #region 报表处理
using (FileStream file = new FileStream(@"C:\Inetpub\wwwroot\ClientBin\RptBasic\Rpt_mrp_DepInOut.xls", FileMode.Open, FileAccess.Read))
{ NPOI.HSSF.UserModel.HSSFWorkbook book = new NPOI.HSSF.UserModel.HSSFWorkbook(file);
NPOI.SS.UserModel.ISheet sheet = book.GetSheet("Sheet1");
ExcelSetValue(sheet, 0, 0, dt.Rows[0]["myconame"].ToString() + kind);
ExcelSetValue(sheet, 3, 1, dt.Rows[0]["coname"].ToString());
ExcelSetValue(sheet, 3, 3, dt.Rows[0]["Tel"].ToString());
ExcelSetValue(sheet, 3, 6, dt.Rows[0]["sNum"].ToString());
ExcelSetValue(sheet, 4, 1, dt.Rows[0]["Address"].ToString());
ExcelSetValue(sheet, 4, 3, dt.Rows[0]["Lineman"].ToString());
ExcelSetValue(sheet, 4, 6, dt.Rows[0]["sdate"].ToString());
ExcelSetValue(sheet, 28, 4, dt.Rows[0]["AuditMan"].ToString());
ExcelSetValue(sheet, 28, 7, dt.Rows[0]["upby"].ToString()); int row = 7;
for (int i = 0; i < dtd.Rows.Count; i++)
{
ExcelSetValue(sheet, i + row, 0, dtd.Rows[i]["sNum"].ToString());
ExcelSetValue(sheet, i + row, 1, dtd.Rows[i]["itemname"].ToString());
ExcelSetValue(sheet, i + row, 02, dtd.Rows[i]["model"].ToString());
ExcelSetValue(sheet, i + row, 03, dtd.Rows[i]["unit"].ToString());
ExcelSetValue(sheet, i + row, 04, dtd.Rows[i]["num"].ToString());
ExcelSetValue(sheet, i + row, 05, dtd.Rows[i]["price"].ToString());
ExcelSetValue(sheet, i + row, 06, dtd.Rows[i]["sum"].ToString());
ExcelSetValue(sheet, i + row, 07, dtd.Rows[i]["remark"].ToString());
}
sheet.ForceFormulaRecalculation = true;
// 另存为
using (FileStream f = new FileStream(@"C:\Inetpub\wwwroot\ClientBin\Rpt\" + filename + ".xls", FileMode.Create, FileAccess.ReadWrite))
{
book.Write(f);
} }
#endregion

其中的设置单元格值的方法

     protected void ExcelSetValue(NPOI.SS.UserModel.ISheet sheet, int Row, int Cell,string sValue)
{
if (sheet.GetRow(Row) == null)
sheet.CreateRow(Row);
if (sheet.GetRow(Row).GetCell(Cell) == null)
sheet.GetRow(Row).CreateCell(Cell);
double d;
if (double.TryParse(sValue, out d))
{
sheet.GetRow(Row).GetCell(Cell).SetCellValue(d);
}
else
sheet.GetRow(Row).GetCell(Cell).SetCellValue(sValue);
}

http://www.shenou123.com/

基于Silverlight 永久免费的仓库管理系统

日记帐系统承接定制开发管理软件 网页游戏辅助等

NPOI之使用EXCEL模板创建报表的更多相关文章

  1. jxls实现基于excel模板的报表

    此文章是基于 搭建Jquery+SpringMVC+Spring+Hibernate+MySQL平台 一. jar包介绍 1. commons-collections-3.2.jar 2. commo ...

  2. ASP.NET使用NPOI加载Excel模板并导出下载

    1.为什么要使用NPOI导出Excel? 一.解决传统操作Excel遇到的问题: 如果是.NET,需要在服务器端装Office,且及时更新它,以防漏洞,还需要设定权限允许.NET访问COM+,如果在导 ...

  3. NPOI的使用Excel模板导出

    private string ExportScMeeting(DataTable source) { string templateFile = Server.MapPath(@"Excel ...

  4. NPOI的使用Excel模板导出 可插入到指定行

    Excel模版建议把需要添加数据行的样式设置好 模版样式,导出后效果 [2017-11-22 对获取需插入数据的首行样式有时为空报错修改] /// <summary> /// 根据模版导出 ...

  5. 在服务端C#如何利用NPOI构建Excel模板

    目前本人接触过两种模板导出的方式:(1)C#利用NPOI接口制作Excel模板,在服务端用数据渲染模板(2)在前端利用前人搭建好的框架,利用office编写xml制作模板,在客户端进行数据的渲染,导出 ...

  6. .Net NPOI 根据excel模板导出excel、直接生成excel

    一.根据Excel模板导出excel 1.导入NPOI.dll  2.DAL中添加类ExportExcel.cs using NPOI.SS.UserModel; using System; usin ...

  7. ASP.NET Core 2.2 : 十六.扒一扒新的Endpoint路由方案 try.dot.net 的正确使用姿势 .Net NPOI 根据excel模板导出excel、直接生成excel .Net NPOI 上传excel文件、提交后台获取excel里的数据

    ASP.NET Core 2.2 : 十六.扒一扒新的Endpoint路由方案   ASP.NET Core 从2.2版本开始,采用了一个新的名为Endpoint的路由方案,与原来的方案在使用上差别不 ...

  8. c#操作Excel模板,替换命名单元格或关键字形成报表

    c#操作Excel模板,替换命名单元格或关键字形成报表 http://blog.sina.com.cn/s/blog_45eaa01a0102vqma.html一 建立Excel 模板文件 templ ...

  9. NPOI操作EXCEL(六)——矩阵类表头EXCEL模板的解析

    哈哈~~~很高兴还活着.总算加班加点的把最后一类EXCEL模板的解析做完了... 前面几篇文章介绍了博主最近项目中对于复杂excel表头的解析,写得不好,感谢园友们的支持~~~ 今天再简单讲诉一下另一 ...

随机推荐

  1. 卸载rpm包提示:error: specifies multiple packages

    –allmatches  Remove all versions of the package which match PACKAGE_NAME. Normally an error is issue ...

  2. linux下单独安装oracle12.1客户端

    1.安装oracle-instantclient:(默认安装即可) oracle-instantclient12.1-sqlplus-12.1.0.1.0-1.x86_64.rpmoracle-ins ...

  3. mysql 主从复制配置步骤

    1.准备两台数据库环境,或者单台多实例环境,能否正常启动和登录. 2.配置my.cnf文件,主库配置log-bin和server-id参数,从库配置server-id,不能和主库及其他从库一样,一般不 ...

  4. 网站发布在另外一个网站下面配置伪静态之后图片样式和JS丢失

    <script src="<%=ResolveClientUrl("~/content/js/jquery-1.7.1.min.js") %>" ...

  5. sql两个表联合更新

    update TableA set id=TableB.id from TableA,TableB where TableA.name=TableB.name

  6. 客户Oracle数据库在插入数据的时候报超出最大长度的错误(规避风险)

    背景: 项目使用oracle数据,在开发环境测试一些正常.项目部署到客户的服务器上后,系统在添加数据的时候报错.输出错误信息,发现是“超出最大长度”的异常. 但是按照数据库的设计,添加的数据应该在允许 ...

  7. 转 Oracle全文检索http://docs.oracle.com/cd/E11882_01/text.112/e24436/toc.htm

    SQL > exec ctx_ddl.create_preference ('my_test_lexer','chinese_lexer') : PL/SQL 过程成功完成 SQL > E ...

  8. asp.net 如何改变GridView搜索出来关键字的颜色?就像百度似的,我获得的是一个集合,改变集合中关键字的集合

    输入“产量”查询,将“产量”拆分,产.量 string strColNameCnDt = string.Empty;            for (int j = 0; j < dtTemp. ...

  9. Struts2+Spring3+Hibernate3+Maven构建(基于Eclipse)

    长时间不做后台了,整理一下资料,以便翻阅. Eclipse.JDK安装略…… Maven下载地址:http://maven.apache.org/download.cgi 版本比较新的Eclipse基 ...

  10. [C入门 - 游戏编程系列] 贪吃蛇篇(六) - 蛇实现

    这一篇是关于设置蛇的属性的,接上一篇(五). 设置蛇的速度,很简单,只要不是负数就行了. void SNK_SetSnakeSpeed(Snake *snake, int speed) { ) sna ...