温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

将dataGridView内容导出到Excel文件

发布时间:2020-08-10 20:42:26 来源:ITPUB博客 阅读:170 作者:llnnmc 栏目:编程语言

这里提供了两种将DataGridView内容导出到Excel文件的方法。

方法1:

/// <summary>
/// 在没有安装Excel的情况下,将DataGridView数据导出到Excel
/// </summary>
private void ExportToExcel()
{
    SaveFileDialog saveFileDialog = new SaveFileDialog();
    saveFileDialog.Filter = "Execl files (*.xls)|*.xls";
    saveFileDialog.FilterIndex = 0;
    saveFileDialog.RestoreDirectory = true;
    saveFileDialog.CreatePrompt = true;
    saveFileDialog.Title = "导出到Excel";
    saveFileDialog.ShowDialog();
    if (saveFileDialog.FileName == "")
    {
        return;
    }
    Stream myStream = saveFileDialog.OpenFile();
    StreamWriter sw = new StreamWriter(myStream, System.Text.Encoding.GetEncoding(-0));
    string str = "";
    try
    {
        for (int i = 0; i < dataGridView1.ColumnCount; i++)
        {
            if (dataGridView1.Columns[i].Visible == false || dataGridView1.Columns[i].DataPropertyName == "")
            {
                continue;
            }
            str += dataGridView1.Columns[i].HeaderText;
            str += "\t";
        }
        sw.WriteLine(str);
        for (int j = 0; j < dataGridView1.Rows.Count - 1; j++)
        {
            string strTemp = "";
            for (int k = 0; k < dataGridView1.Columns.Count; k++)
            {
                if (dataGridView1.Columns[k].Visible == false || dataGridView1.Columns[k].DataPropertyName == "")
                {
                    continue;
                }
                object obj = dataGridView1.Rows[j].Cells[k].Value;
                if (obj != null)
                {
                    strTemp += dataGridView1.Rows[j].Cells[k].Value.ToString();
                }
                else
                {
                    strTemp = "";
                }
                strTemp += "\t";
            }
            sw.WriteLine(strTemp);
        }
        sw.Close();
        myStream.Close();
        MessageBox.Show("成功导出到Excel文件:\n" + saveFileDialog.FileName);
    }
    catch (Exception ex)
    {
        MessageBox.Show(ex.ToString());
    }
    finally
    {
        sw.Close();
        myStream.Close();
    }
}

方法2:

/// <summary>
/// 将DataGrirdView数据导出到Excel
/// 需要引用Microsoft.Office.Interop.Excel.dll模块
/// </summary>
/// <param name="dgv"></param>
/// <param name="bShowExcel"></param>
/// <returns></returns>
private bool DataGridviewShowToExcel(DataGridView dgv, bool bShowExcel)
{
    if (dgv.Rows.Count == 0)
    {
        return false;
    }
    //建立Excel对象      
    Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application();
    excel.Application.Workbooks.Add(true);
    excel.Visible = bShowExcel;
    //生成字段名称    
    int k = 0;
    for (int i = 0; i < dgv.ColumnCount; i++)
    {
        if (dgv.Columns[i].Visible == false || dataGridView1.Columns[i].DataPropertyName == "")
        {
            k++;
            continue;
        }
        excel.Cells[1, i + 1 - k] = dgv.Columns[i].HeaderText;
    }
    //填充数据     
    for (int i = 0; i < dgv.RowCount; i++)
    {
        k = 0;
        for (int j = 0; j < dgv.ColumnCount; j++)
        {
            if (dgv.Columns[j].Visible == false || dataGridView1.Columns[j].DataPropertyName == "")
            {
                k++;
                continue;
            }
            excel.Cells[i + 2, j + 1 - k] = dgv[j, i].Value.ToString();
        }
    }
    return true;
}
向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI