zoukankan      html  css  js  c++  java
  • 导出Excel

    做统计类的项目是不可比避免的会遇到把数据做成文档

    下面是Excel问当的生成

     public class ExportDataHelper
        {
            //路径
            public static string Path
            {
                get;
                set;
            }
            //名称加后缀名
            public static string FileName
            {
                get;
                set;
            }
            public static void ExportAttendance(DataTable dsAtt)
            {
                try
                {
                    if (dsAtt != null && dsAtt.Rows.Count > 0)
                    {
                        XlsDocument doc = new XlsDocument();
                        Workbook wbk = doc.Workbook;
                        Worksheet sht = wbk.Worksheets.Add("Test Sheet");
                        MergeArea meaA;
                        int rowcount = 1;
                        //cell样式
                        XF cellXF = doc.NewXF();//为xls生成一个XF实例(XF是cell格式对象)
                        cellXF.HorizontalAlignment = HorizontalAlignments.Centered;//设定文字居中
                        cellXF.Font.FontName = "宋体";//设定字体
                        cellXF.Font.Height = 15 * 15;//设定字大小(字体大小是以 1/20 point 为单位的)
                        cellXF.UseBorder = true;//使用边框
                        cellXF.BottomLineStyle = 1;//设定边框底线为粗线
                        cellXF.BottomLineColor = Colors.Blue;//设定颜色为暗
                        cellXF.TopLineColor = Colors.Blue;
                        cellXF.TopLineStyle = 1;
                        cellXF.RightLineColor = Colors.Blue;
                        cellXF.RightLineStyle = 1;
                        cellXF.LeftLineColor = Colors.Blue;
                        cellXF.LeftLineStyle = 1;
                        for (int i = 0; i < dsAtt.Columns.Count; i++)
                        {
                            sht.Cells.AddValueCellXF(1, i + 1, dsAtt.Columns[i].ColumnName, cellXF);
                        }
                        for (int j = 0; j < dsAtt.Rows.Count; j++)
                        {
                            rowcount++;
                            for (int c = 0; c < dsAtt.Columns.Count; c++)
                            {
                                //生成格子
                                sht.Cells.AddValueCellXF(rowcount, c + 1, Convert.ToString(dsAtt.Rows[j][dsAtt.Columns[c].ColumnName]), cellXF);
                            }
                        }
                        doc.FileName = FileName;
                        doc.Save(Path, true);
                    }
                }
                catch (Exception e)
                {
                    throw e;
                }
            }
           
        }
    
    
    ----------------------------------
            //改变列名   改变列名过后再再导出Excel
            public static DataTable CreateNewDiskTable(DataTable data)
            {
                var table = new DataTable();
                GetNewDiskColumn(table);
                foreach (DataRow row in data.Rows)
                {
                    var newRow = table.NewRow();
                    newRow["邮寄会员"] = row["Name"];
                    newRow["邮寄地址"] = row["Address"];
                    newRow["邮寄电话"] = row["Phone"];
                    //newRow["邮编"] = row["ConfirmZipCode"];
                    table.Rows.Add(newRow);
                }
                return table;
            }
            private static void GetNewDiskColumn(DataTable dt)
            {
                DataColumn dcName = new DataColumn();
                dcName.ColumnName = "邮寄会员";
                dt.Columns.Add(dcName);
                DataColumn dcAddress = new DataColumn();
                dcAddress.ColumnName = "邮寄地址";
                dt.Columns.Add(dcAddress);
                DataColumn dcPhone = new DataColumn();
                dcPhone.ColumnName = "邮寄电话";
                dt.Columns.Add(dcPhone);
                //DataColumn dcZipCode = new DataColumn();
                //dcZipCode.ColumnName = "邮编";
                //dt.Columns.Add(dcZipCode);
            }
    View Code
  • 相关阅读:
    [NOI2003],[AHOI2006]文本编辑器
    luogu P5151 HKE与他的小朋友
    [NOI2005]维护数列
    [HNOI2012]永无乡
    luogu P4146 序列终结者
    [SCOI2016]美味
    UVA1451 Average
    [JSOI2007]字符加密
    luogu P3809 【模板】后缀排序
    CentOS 7系统启动后怎么从命令行模式切换到图形界面模式
  • 原文地址:https://www.cnblogs.com/bit-by-bit/p/3915436.html
Copyright © 2011-2022 走看看