NPOI之使用EXCEL模板建立報表

weixin_34041003發表於2013-09-05

因為專案中要用到伺服器端建立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 永久免費的倉庫管理系統 

日記帳系統承接定製開發管理軟體 網頁遊戲輔助等

 

相關文章