Winform DataGridView控件数据导出EXcel
Posted 西枫叶落
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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;
}
}
以上是关于Winform DataGridView控件数据导出EXcel的主要内容,如果未能解决你的问题,请参考以下文章
用c#winform拖的datagridview控件,当选中一行数据以后鼠标离开之后,就选不中了
Winform 下,两个不同窗体的DataGridView控件中的数据间传值怎么解决?
Winform控件之DataGridView数据控件显示问题