winform导出dataviewgrid数据为excel

 #region 导出dataViewGrid视图中的数据为xls格式
        private void btnExportList_Click(object sender, EventArgs e)
        {
            string fname = string.Empty;

            SaveFileDialog sfd = new SaveFileDialog();

            sfd.Filter = "表格文件|*.xls";
            sfd.DefaultExt = "xls";

            if (sfd.ShowDialog() == DialogResult.OK)
            {
                fname = sfd.FileName;
            }
            else
            {
                return;
            }

            //导出当前dataGridView中的所有数据到xls文件
            //1.引入库文件,新建lib文件夹,复制相关文件
            //2.在项目中添加对这几个dll的引用
            //3.在内存中建立 excel表文件
            HSSFWorkbook workbook = new HSSFWorkbook();
            HSSFSheet sheet = workbook.CreateSheet("第一页");

            //创建标题头
            HSSFRow title = sheet.CreateRow(0);
            title.CreateCell(0).SetCellValue("编号");
            title.CreateCell(1).SetCellValue("姓名");
            title.CreateCell(2).SetCellValue("性别");
            title.CreateCell(3).SetCellValue("年龄");
            title.CreateCell(4).SetCellValue("地址");
            title.CreateCell(5).SetCellValue("电话");
            title.CreateCell(6).SetCellValue("生日");
            for (int rowindex = 0; rowindex < dgvStudens.RowCount; rowindex++)
            {
                //创建第一行
                HSSFRow row = sheet.CreateRow(rowindex + 1);

                for (int colindex = 0; colindex < dgvStudens.Rows[rowindex].Cells.Count; colindex++)
                {
                    row.CreateCell(colindex).SetCellValue((dgvStudens.Rows[rowindex].Cells[colindex].Value == null) ? null : dgvStudens.Rows[rowindex].Cells[colindex].Value.ToString());
                }
                创建第一行的第一列
                //HSSFCell cell = row.CreateCell(0);
                //cell.SetCellType(3);
                //cell.SetCellValue(dgvStudens.Rows[rowindex].Cells[0].Value.ToString());
                第一行第2列
                //row.CreateCell(1).SetCellValue(dgvStudens.Rows[rowindex].Cells[1].Value.ToString());
                第一行第3列
                //row.CreateCell(2).SetCellValue(dgvStudens.Rows[rowindex].Cells[2].Value.ToString());
                第一行第4列,age,可能会为空
                 row.CreateCell(3).SetCellValue(dgvStudens.Rows[0].Cells[3].Value.ToString());
                //row.CreateCell(3).SetCellValue((dgvStudens.Rows[rowindex].Cells[3].Value == null) ? null : dgvStudens.Rows[rowindex].Cells[3].Value.ToString());
            }

            using (FileStream fs = new FileStream(fname, FileMode.Create))
            {

                workbook.Write(fs);
            }

            ;

        } 
        #endregion

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值