C#中将dataGridView导到excel

工程中-右击引用-添加-COM-选择microsoft excel
1.先去导入dll库:Microsoft.Office.Interop.Excel.dl

这里写图片描述
这里写图片描述
2.然后再去写代码:

using System;  
using System.Collections.Generic;  
using System.Linq;  
using System.Text;  
using Microsoft.Office.Interop;  
using Microsoft.Office.Interop.Excel;  
using System.Windows.Forms;  
using Excel = Microsoft.Office.Interop.Excel;  
public class ExprotToExcel
{
    public void DataToExcel(DataGridView dgv, ToolStripProgressBar tempProgressBar, ToolStripStatusLabel toolstrip)
    {
        if (dgv.Rows.Count == 0)
        {
            MessageBox.Show("无数据"); return;
        }
        MessageBox.Show("开始生成要导出的数据", "导出提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
        Excel.Application excel = new Excel.Application();
        excel.Application.Workbooks.Add(true);
        excel.Visible = false;
        for (int i = 0; i < dgv.ColumnCount; i++)
            excel.Cells[1, i + 1] = dgv.Columns[i].HeaderText;
        tempProgressBar.Visible = true;
        tempProgressBar.Minimum = 1;
        tempProgressBar.Maximum = dgv.RowCount;
        tempProgressBar.Step = 1;
        toolstrip.Visible = true;
        for (int i = 0; i < dgv.RowCount; i++)
        {
            for (int j = 0; j < dgv.ColumnCount; j++)
            {
                if (dgv[j, i].ValueType == typeof(string))
                {
                    excel.Cells[i + 2, j + 1] = "'" + dgv[j, i].Value.ToString();
                }
                else
                {
                    excel.Cells[i + 2, j + 1] = dgv[j, i].Value.ToString();
                }
            }
            toolstrip.Text = "|| 状态:正在生成第 " + i + "/" + dgv.RowCount + " 个";
            tempProgressBar.Value = i + 1;
        }
        toolstrip.Text = "|| 状态:生成成功!";
        MessageBox.Show("生成成功,请保存。", "生成提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
        excel.Visible = true;
    }
}

电脑装OFFICE2007的话,
这里写图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值