• Winform DataGridView控件数据导出EXcel


    /// <summary>
    /// 导出Excel
    /// </summary>
    /// <param name="dgv"></param>
    /// <param name="tempProgressBar"></param>
    /// <param name="toolstrip"></param>
    public void DataToExcel(DataGridView dgv, ProgressBar tempProgressBar, Label toolstrip)
    {
    if (dgv.Rows.Count == 0)
    {
    MessageBox.Show("无数据"); return;
    }
    //MessageBox.Show("开始生成要导出的数据", "导出提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
    if (MessageBox.Show("是否开始生成要导出的数据?", "导出提示", MessageBoxButtons.YesNo, MessageBoxIcon.Information) == DialogResult.Yes)
    {
    this.progressBar1.Visible = true;
    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 = "|| 状态:生成Excel成功!";
    MessageBox.Show("生成成功,请保存。", "生成提示", MessageBoxButtons.OK, MessageBoxIcon.Information);
    excel.Visible = true;
    }
    }

  • 相关阅读:
    《自我介绍》
    《结对-结对编项目作业名称-开发环境搭建过程》
    提取图形中指定颜色的所有像素_opencv/c++
    图形锐化_opencv/C++
    Opencv2.4.13 与Visual Studio2013 环境搭建配置
    C++基础——C面向过程与C++面向对象编程01_圆面积求解
    2017年2月26日
    基于GDAL的遥感影像显示(C#版)
    GDAL C# 开发环境配置
    shp文件的读取
  • 原文地址:https://www.cnblogs.com/xifengyeluo/p/6410296.html
Copyright © 2020-2023  润新知