asp.net使用模板导出excel

发布时间:2018-10-19编辑:佚名阅读(2119)

public void OutputExcel(DataView dv, string str)  
    {  
        #region  
        GC.Collect();  
  
        //ExcelOperate excelOperate = new ExcelOperate();  
        Application excel;// = new Application();  
        //int rowIndex = 4;  
        //int colIndex = 1;  
  
        _Workbook xBk;  
        _Worksheet xSt;  
  
        excel = new ApplicationClass();  
  
        xBk = excel.Workbooks.Add(Server.MapPath("xls_template") + "//标准工时模板.xls");  
  
        xSt = (_Worksheet)xBk.ActiveSheet;  
  
        xSt.get_Range(xSt.Cells[2, 1], xSt.Cells[2, 9]).Merge(Missing.Value); //横向合并  
        xSt.get_Range(xSt.Cells[2, 1], xSt.Cells[2, 1]).Value2 = GetDept(Session["sa_kb"].ToString()) + "    " + "标准工时";  
        //13838  
        xSt.Cells[3, 1] = "成品料号:" + Session["sa001"].ToString();  
        xSt.Cells[3, 3] = "型号:" + Session["sa02x"].ToString();  
        xSt.Cells[3, 8] = "版次/版本:" + Session["banchi"].ToString();  
        xSt.Cells[4, 1] = "半成品料号:" + Session["sa011"].ToString();  
        xSt.Cells[4, 3] = "订单:" + Session["sa_NO"].ToString();  
        xSt.Cells[4, 8] = "IE:" + Session["sa_IE"].ToString();  
        for (int i = 0; i < dv.Count; i++)  
        {  
            xSt.Cells[7 + i, 1] = dv[i].Row[0].ToString();  
  
            xSt.Cells[7 + i, 2] = dv[i].Row[1].ToString();  
            xSt.Cells[7 + i, 3] = dv[i].Row[3].ToString();  
            xSt.Cells[7 + i, 4] = dv[i].Row[4].ToString();  
            xSt.Cells[7 + i, 5] = dv[i].Row[5].ToString();  
  
            if (dv[i].Row[2].ToString() == "1")//若是有数据变更的则着色表示  
            {  
  
                SetBold(xSt, xSt.Cells[7 + i, 1], xSt.Cells[7 + i, 9], 1);  
  
            }  
  
  
            SetHAlignCenter(xSt, xSt.Cells[7 + i, 6], xSt.Cells[7 + i, 9]);//居中  
  
        }  
        int rowNum = 7;  
        DataView dvw = GetBiao();  
        for (int i = 0; i < dvw.Count; i++)  
        {  
            int rowAdd = Convert.ToInt32(dvw[i].Row[1].ToString());  
  
            xSt.get_Range(xSt.Cells[rowNum, 6], xSt.Cells[rowNum + rowAdd - 1, 6]).Merge(Missing.Value);  
            xSt.get_Range(xSt.Cells[rowNum, 6], xSt.Cells[rowNum + rowAdd - 1, 6]).Value2 = dvw[i].Row[2].ToString();  
            xSt.get_Range(xSt.Cells[rowNum, 7], xSt.Cells[rowNum + rowAdd - 1, 7]).Merge(Missing.Value);  
            xSt.get_Range(xSt.Cells[rowNum, 7], xSt.Cells[rowNum + rowAdd - 1, 7]).Value2 = dvw[i].Row[3].ToString();  
            xSt.get_Range(xSt.Cells[rowNum, 8], xSt.Cells[rowNum + rowAdd - 1, 8]).Merge(Missing.Value);  
            xSt.get_Range(xSt.Cells[rowNum, 8], xSt.Cells[rowNum + rowAdd - 1, 8]).Value2 = dvw[i].Row[4].ToString();  
            xSt.get_Range(xSt.Cells[rowNum, 9], xSt.Cells[rowNum + rowAdd - 1, 9]).Merge(Missing.Value);  
            xSt.get_Range(xSt.Cells[rowNum, 9], xSt.Cells[rowNum + rowAdd - 1, 9]).Value2 = dvw[i].Row[6].ToString();  
            rowNum = rowNum + rowAdd;  
  
        }  
  
        xSt.get_Range(xSt.Cells[(int)dv.Count + 7, 1], xSt.Cells[(int)dv.Count + 7, 2]).Merge(Missing.Value);  
        xSt.get_Range(xSt.Cells[(int)dv.Count + 7, 1], xSt.Cells[(int)dv.Count + 7, 2]).Value2 = "间接人员";  
        #region  
        int dvc = (int)dv.Count + 7;  
        xSt.Cells[dvc + 1, 1] = "1";  
        xSt.Cells[dvc + 2, 1] = "2";  
        xSt.Cells[dvc + 3, 1] = "3";  
        xSt.Cells[dvc + 1, 2] = "修改";  
        xSt.Cells[dvc + 2, 2] = "调机";  
        xSt.Cells[dvc + 3, 2] = "备注";  
        string[] str1 = GetSum("1").Split(';');  
        xSt.Cells[dvc + 1, 3] = str1[0];  
        xSt.Cells[dvc + 1, 4] = str1[1];  
        xSt.Cells[dvc + 1, 5] = str1[2];  
        xSt.Cells[dvc + 1, 6] = str1[3];  
        string[] str2 = GetSum("2").Split(';');  
        xSt.Cells[dvc + 2, 3] = str2[0];  
        xSt.Cells[dvc + 2, 4] = str2[1];  
        xSt.Cells[dvc + 2, 5] = str2[2];  
        xSt.Cells[dvc + 2, 6] = str2[3];  
        string[] str3 = GetSum("3").Split(';');  
        xSt.Cells[dvc + 3, 3] = str3[0];  
        xSt.Cells[dvc + 3, 4] = str3[1];  
        xSt.Cells[dvc + 3, 5] = str3[2];  
        xSt.Cells[dvc + 3, 6] = str3[3];  
        #endregion  
  
        int ExRow = (int)dv.Count + 12;  
        // 将图片写入到Excel  
        xSt.get_Range(xSt.Cells[ExRow, 6], xSt.Cells[ExRow + 6, 9]).Merge(Missing.Value);  
        Worksheet wk = (Worksheet)xSt;  
        int heit = ((int)dv.Count) * 22;  
        heit = heit - 30;  
  
        string strpath = Session["sa010"].ToString();  
        if (strpath != "")  
        {  
            wk.Shapes.AddPicture(strpath, MsoTriState.msoFalse, MsoTriState.msoTrue, 455, heit, 113, 84);  
        }  
        xSt.get_Range(xSt.Cells[ExRow, 6], xSt.Cells[ExRow + 6, 9]).Value2 = "";  
        xSt.Cells[ExRow, 2] = "产线总人数(人):";  
        xSt.Cells[ExRow + 1, 2] = "产线瓶颈时间(秒):";  
        xSt.Cells[ExRow + 2, 2] = "产线平衡率(%):";  
        xSt.Cells[ExRow + 3, 2] = "产品标准工时(秒):";  
        xSt.Cells[ExRow + 4, 2] = "标准日产能(PCS/10H):";  
        //设置位置  
        SetHAlignCenter(xSt, xSt.Cells[ExRow, 2], xSt.Cells[ExRow, 2], "str");  
        SetHAlignCenter(xSt, xSt.Cells[ExRow + 1, 2], xSt.Cells[ExRow + 1, 2], "str");  
        SetHAlignCenter(xSt, xSt.Cells[ExRow + 2, 2], xSt.Cells[ExRow + 2, 2], "str");  
        SetHAlignCenter(xSt, xSt.Cells[ExRow + 3, 2], xSt.Cells[ExRow + 3, 2], "str");  
        SetHAlignCenter(xSt, xSt.Cells[ExRow + 4, 2], xSt.Cells[ExRow + 4, 2], "str");  
        //设置字体产色  
 
        #region  
        SetBold(xSt, xSt.Cells[ExRow, 2], xSt.Cells[ExRow, 2], "");  
        SetBold(xSt, xSt.Cells[ExRow + 1, 2], xSt.Cells[ExRow + 1, 2], "");  
        SetBold(xSt, xSt.Cells[ExRow + 2, 2], xSt.Cells[ExRow + 2, 2], "");  
        SetBold(xSt, xSt.Cells[ExRow + 3, 2], xSt.Cells[ExRow + 3, 2], "");  
        SetBold(xSt, xSt.Cells[ExRow + 4, 2], xSt.Cells[ExRow + 4, 2], "");  
        #endregion  
  
        xSt.get_Range(xSt.Cells[ExRow, 3], xSt.Cells[ExRow, 5]).Merge(Missing.Value);  
        xSt.get_Range(xSt.Cells[ExRow, 3], xSt.Cells[ExRow, 5]).Value2 = GetSum("4");  
        SetBold(xSt, xSt.Cells[ExRow, 3], xSt.Cells[ExRow, 5], "");  
        xSt.get_Range(xSt.Cells[ExRow + 1, 3], xSt.Cells[ExRow + 1, 5]).Merge(Missing.Value);  
        xSt.get_Range(xSt.Cells[ExRow + 1, 3], xSt.Cells[ExRow + 1, 5]).Value2 = GetSum("5");  
        SetBold(xSt, xSt.Cells[ExRow + 1, 3], xSt.Cells[ExRow + 1, 5], "");  
        xSt.get_Range(xSt.Cells[ExRow + 2, 3], xSt.Cells[ExRow + 2, 5]).Merge(Missing.Value);  
        xSt.get_Range(xSt.Cells[ExRow + 2, 3], xSt.Cells[ExRow + 2, 5]).Value2 = GetSum("6");  
        SetBold(xSt, xSt.Cells[ExRow + 2, 3], xSt.Cells[ExRow + 2, 5], "");  
  
        xSt.get_Range(xSt.Cells[ExRow + 3, 3], xSt.Cells[ExRow + 3, 5]).Merge(Missing.Value);  
        xSt.get_Range(xSt.Cells[ExRow + 3, 3], xSt.Cells[ExRow + 3, 5]).Value2 = GetSum("7");  
        SetBold(xSt, xSt.Cells[ExRow + 3, 3], xSt.Cells[ExRow + 3, 5], "");  
        xSt.get_Range(xSt.Cells[ExRow + 4, 3], xSt.Cells[ExRow + 4, 5]).Merge(Missing.Value);  
        xSt.get_Range(xSt.Cells[ExRow + 4, 3], xSt.Cells[ExRow + 4, 5]).Value2 = GetSum("8");  
        SetBold(xSt, xSt.Cells[ExRow + 4, 3], xSt.Cells[ExRow + 4, 5], "");  
        //居中  
        SetHAlignCenter(xSt, xSt.Cells[ExRow, 3], xSt.Cells[ExRow, 5]);  
        SetHAlignCenter(xSt, xSt.Cells[ExRow + 1, 3], xSt.Cells[ExRow + 1, 5]);  
        SetHAlignCenter(xSt, xSt.Cells[ExRow + 2, 3], xSt.Cells[ExRow + 2, 5]);  
        SetHAlignCenter(xSt, xSt.Cells[ExRow + 3, 3], xSt.Cells[ExRow + 3, 5]);  
        SetHAlignCenter(xSt, xSt.Cells[ExRow + 4, 3], xSt.Cells[ExRow + 4, 5]);  
  
        xSt.get_Range(xSt.Cells[ExRow + 5, 1], xSt.Cells[ExRow + 5, 5]).Merge(Missing.Value); //横向合并  
        xSt.get_Range(xSt.Cells[ExRow + 5, 1], xSt.Cells[ExRow + 5, 5]).Value2 = "注: 适用型号: ";  
  
        //  
        //显示效果  
        //  
        excel.Visible = false;  
  
        //xSt.Export(Server.MapPath(".")+"//"+this.xlfile.Text+".xls",SheetExportActionEnum.ssExportActionNone,Microsoft.Office.Interop.OWC.SheetExportFormat.ssExportHTML);  
  
        string stick = DateTime.Now.Ticks.ToString();  
        xBk.SaveCopyAs(Server.MapPath("xls_files") + "//" + stick + ".xls");  
  
        //ds = null;  
        xBk.Close(false, null, null);  
  
        excel.Quit();  
        System.Runtime.InteropServices.Marshal.ReleaseComObject(xBk);  
        System.Runtime.InteropServices.Marshal.ReleaseComObject(excel);  
        System.Runtime.InteropServices.Marshal.ReleaseComObject(xSt);  
        xBk = null;  
        excel = null;  
        xSt = null;  
        GC.Collect();  
        string path = Server.MapPath("xls_files") + "//" + stick + ".xls";  
  
        System.IO.FileInfo file = new System.IO.FileInfo(path);  
        Response.Clear();  
        Response.Charset = "GB2312";  
        Response.ContentEncoding = System.Text.Encoding.UTF8;  
        // 添加头信息,,弹出另存为窗口  
        Response.AddHeader("Content-Disposition", "attachment; filename=" + Server.UrlEncode(file.Name));  
        //让浏览器显示下载信息  
        Response.AddHeader("Content-Length", file.Length.ToString());  
  
        // 指定返回一个不能被客户端读取的流,下载  
        Response.ContentType = "application/ms-excel";  
  
        //把文件流下载到客户端  
        Response.WriteFile(file.FullName);  
        // 停止页面的执行  
  
        Response.End();  
        #endregion  
    }


    关键字: asp.net 模板 导出 excel


鼓掌

0

正能量

0

0

呵呵

0


评论区