C#中导出dataGridView数据为Excel

此代码可以直接使用无需修改

C#中导出dataGridView数据为Excel

#region 导出Excel功能函数
/// <summary>
///  dataGridView 导出Excel功能函数
/// </summary>
/// <param name="dataView">dataGridView数据表</param>
/// <param name="filePath">路径</param>
private void ExportDataToExcel(DataGridView dataView, string filePath)
{
    try
    {
        using (StreamWriter writer = new StreamWriter(filePath, false, Encoding.UTF8))
        {
            // 写入表头
            for (int i = 0; i < dataView.Columns.Count; i++)
            {
                writer.Write(dataView.Columns[i].HeaderText);
                if (i < dataView.Columns.Count - 1)
                {
                    writer.Write(",");
                }
            }
            writer.WriteLine();

            // 写入数据
            foreach (DataGridViewRow row in dataView.Rows)
            {
                if (!row.IsNewRow) // 忽略新行
                {
                    for (int i = 0; i < dataView.Columns.Count; i++)
                    {
                        writer.Write(row.Cells[i].Value?.ToString());
                        if (i < dataView.Columns.Count - 1)
                        {
                            writer.Write(",");
                        }
                    }
                    writer.WriteLine();
                }
            }
        }

        MessageBox.Show("Data exported successfully.", "Success", MessageBoxButtons.OK, MessageBoxIcon.Information);
    }
    catch (Exception ex)
    {
        MessageBox.Show("Error exporting data: " + ex.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
    }
}

#endregion

按键

     private void menuExportFile_Click(object sender, EventArgs e)
     {
         using (SaveFileDialog saveFileDialog = new SaveFileDialog())
         {
             saveFileDialog.Filter = "Excel files (*.xlsx)|*.xlsx|CSV files (*.csv)|*.csv";
             saveFileDialog.Title = "Save as";
             saveFileDialog.FileName = $"{DateTime.Now:yyyyMMddHHmmss}"; // 默认文件名,以当前时间命名

             if (saveFileDialog.ShowDialog() == DialogResult.OK)
             {
                 string filePath = saveFileDialog.FileName;
                 string fileExtension = Path.GetExtension(filePath).ToLower();

                 if (fileExtension == ".csv")
                 {
                     ExportDataToExcel(dataView,filePath);
                 }
                 else if (fileExtension == ".xlsx")
                 {
                     ExportDataToExcel(dataView, filePath);
                 }
                 else
                 {
                     MessageBox.Show("Unsupported file format.", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
                 }
             }
         }
     }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

好玩的Matlab(NCEPU)

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

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

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

打赏作者

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

抵扣说明:

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

余额充值