winform导出excel

winform导出excel

1. 拖控件-button

在这里插入图片描述

2. 准备datatable数据

DataTable dt = new DataTable();
            dt.Columns.Add("name");
            dt.Columns.Add("age");

            DataRow dr = null;
            dr = dt.NewRow();
            dr["name"] = "zhangsan拉拉";
            dr["age"] = "18";
            dt.Rows.Add(dr);

            dr = dt.NewRow();
            dr["name"] = "lisi拉拉";
            dr["age"] = "19";
            dt.Rows.Add(dr);

3. button点击事件

private void button1_Click(object sender, EventArgs e)
        {
            DataTable dt = new DataTable();
            dt.Columns.Add("name");
            dt.Columns.Add("age");

            DataRow dr = null;
            dr = dt.NewRow();
            dr["name"] = "zhangsan拉拉";
            dr["age"] = "18";
            dt.Rows.Add(dr);

            dr = dt.NewRow();
            dr["name"] = "lisi拉拉";
            dr["age"] = "19";
            dt.Rows.Add(dr);

            DataTableToExcel(dt, AppDomain.CurrentDomain.SetupInformation.ApplicationBase+"/test3.xls");
        }

        public static void DataTableToExcel(DataTable dt, string path)
        {
            HSSFWorkbook workbook = new HSSFWorkbook();
            //创建工作表 
            ISheet sheet = string.IsNullOrEmpty(dt.TableName) ? workbook.CreateSheet("Sheet1") : workbook.CreateSheet(dt.TableName);
            #region 标题
            //在工作表中添加一行
            IRow row = sheet.CreateRow(0);
            for (int i = 0; i < dt.Columns.Count; i++)
            {
                //在行中添加一列
                ICell cell = row.CreateCell(i);
                //设置列的内容	 
                cell.SetCellValue(dt.Columns[i].ColumnName);
            }
            #endregion
            #region 填充数据
            for (int i = 1; i <= dt.Rows.Count; i++)//遍历DataTable行
            {
                DataRow dataRow = dt.Rows[i - 1];
                row = sheet.CreateRow(i);//在工作表中添加一行

                for (int j = 0; j < dt.Columns.Count; j++)//遍历DataTable列
                {
                    ICell cell = row.CreateCell(j);//在行中添加一列
                    cell.SetCellValue(dataRow[j].ToString());//设置列的内容	 
                }
            }
            #endregion
            #region 输出Excel
            MemoryStream ms = new MemoryStream();
            workbook.Write(ms);
            using (FileStream fs = new FileStream(path, FileMode.Create, FileAccess.Write))
            {
                byte[] bArr = ms.ToArray();
                fs.Write(bArr, 0, bArr.Length);
                fs.Flush();
            }
            #endregion
        }
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

星银色飞行船

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值