热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

asp.netDataGridView导出到Excel的三个方法[亲测]

#region DataGridView数据显示到Excel    ///  &
#region DataGridView数据显示到Excel   
///     
/// 打开Excel并将DataGridView控件中数据导出到Excel   
/// 
    
/// DataGridView对象     
/// 是否显示Excel界面     
///    
/// add com "Microsoft Excel 11.0 Object Library"   
/// using Excel=Microsoft.Office.Interop.Excel;   
/// 
   
///      
public bool DataGridviewShowToExcel(DataGridView dgv, bool isShowExcle)   
{   
    if (dgv.Rows.Count == 0)   
        return false;   
    //建立Excel对象    
    Excel.Application excel = new Excel.Application();   
    excel.Application.Workbooks.Add(true);   
    excel.Visible = isShowExcle;   
    //生成字段名称    
    for (int i = 0; i < dgv.ColumnCount; i++)   
    {   
        excel.Cells[1, i + 1] = dgv.Columns[i].HeaderText;   
    }   
    //填充数据    
    for (int i = 0; i < dgv.RowCount - 1; 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();   
            }   
        }   
    }   
    return true;   
}  
#endregion   

#region DateGridView导出到csv格式的Excel   
///    
/// 常用方法,列之间加\t,一行一行输出,此文件其实是csv文件,不过默认可以当成Excel打开。   
/// 
   
///    
/// using System.IO;   
/// 
   
///    
private void DataGridViewToExcel(DataGridView dgv)   
{   
    SaveFileDialog dlg = new SaveFileDialog();   
    dlg.Filter = "Execl files (*.xls)|*.xls";   
    dlg.FilterIndex = 0;   
    dlg.RestoreDirectory = true;   
    dlg.CreatePrompt = true;   
    dlg.Title = "保存为Excel文件";   

    if (dlg.ShowDialog() == DialogResult.OK)   
    {   
        Stream myStream;   
        myStream = dlg.OpenFile();   
        StreamWriter sw = new StreamWriter(myStream, System.Text.Encoding.GetEncoding(-0));   
        string columnTitle = "";   
        try  
        {   
            //写入列标题   
            for (int i = 0; i < dgv.ColumnCount; i++)   
            {   
                if (i > 0)   
                {   
                    columnTitle += "\t";   
                }   
                columnTitle += dgv.Columns[i].HeaderText;   
            }   
            sw.WriteLine(columnTitle);   

            //写入列内容   
            for (int j = 0; j < dgv.Rows.Count; j++)   
            {   
                string columnValue = "";   
                for (int k = 0; k < dgv.Columns.Count; k++)   
                {   
                    if (k > 0)   
                    {   
                        columnValue += "\t";   
                    }   
                    if (dgv.Rows[j].Cells[k].Value == null)   
                        columnValue += "";   
                    else  
                        columnValue += dgv.Rows[j].Cells[k].Value.ToString().Trim();   
                }   
                sw.WriteLine(columnValue);   
            }   
            sw.Close();   
            myStream.Close();   
        }   
        catch (Exception e)   
        {   
            MessageBox.Show(e.ToString());   
        }   
        finally  
        {   
            sw.Close();   
            myStream.Close();   
        }   
    }   
}   
#endregion  

#region DataGridView导出到Excel,有一定的判断性   
///     
///方法,导出DataGridView中的数据到Excel文件    
/// 
    
///    
/// add com "Microsoft Excel 11.0 Object Library"   
/// using Excel=Microsoft.Office.Interop.Excel;   
/// using System.Reflection;   
/// 
   
///  DataGridView     
public static void DataGridViewToExcel(DataGridView dgv)   
{  

 
    #region   验证可操作性   

    //申明保存对话框    
    SaveFileDialog dlg = new SaveFileDialog();   
    //默然文件后缀    
    dlg.DefaultExt = "xls ";   
    //文件后缀列表    
    dlg.Filter = "EXCEL文件(*.XLS)|*.xls ";   
    //默然路径是系统当前路径    
    dlg.InitialDirectory = Directory.GetCurrentDirectory();   
    //打开保存对话框    
    if (dlg.ShowDialog() == DialogResult.Cancel) return;   
    //返回文件路径    
    string fileNameString = dlg.FileName;   
    //验证strFileName是否为空或值无效    
    if (fileNameString.Trim() == " ")   
    { return; }   
    //定义表格内数据的行数和列数    
    int rowscount = dgv.Rows.Count;   
    int colscount = dgv.Columns.Count;   
    //行数必须大于0    
    if (rowscount <= 0)   
    {   
        MessageBox.Show("没有数据可供保存 ", "提示 ", MessageBoxButtons.OK, MessageBoxIcon.Information);   
        return;   
    }   

    //列数必须大于0    
    if (colscount <= 0)   
    {   
        MessageBox.Show("没有数据可供保存 ", "提示 ", MessageBoxButtons.OK, MessageBoxIcon.Information);   
        return;   
    }   

    //行数不可以大于65536    
    if (rowscount > 65536)   
    {   
        MessageBox.Show("数据记录数太多(最多不能超过65536条),不能保存 ", "提示 ", MessageBoxButtons.OK, MessageBoxIcon.Information);   
        return;   
    }   

    //列数不可以大于255    
    if (colscount > 255)   
    {   
        MessageBox.Show("数据记录行数太多,不能保存 ", "提示 ", MessageBoxButtons.OK, MessageBoxIcon.Information);   
        return;   
    }   

    //验证以fileNameString命名的文件是否存在,如果存在删除它    
    FileInfo file = new FileInfo(fileNameString);   
    if (file.Exists)   
    {   
        try  
        {   
            file.Delete();   
        }   
        catch (Exception error)   
        {   
            MessageBox.Show(error.Message, "删除失败 ", MessageBoxButtons.OK, MessageBoxIcon.Warning);   
            return;   
        }   
    }  
    #endregion   
    Excel.Application objExcel = null;   
    Excel.Workbook objWorkbook = null;   
    Excel.Worksheet objsheet = null;   
    try  
    {   
        //申明对象    
        objExcel = new Microsoft.Office.Interop.Excel.Application();   
        objWorkbook = objExcel.Workbooks.Add(Missing.Value);   
        objsheet = (Excel.Worksheet)objWorkbook.ActiveSheet;   
        //设置EXCEL不可见    
        objExcel.Visible = false;   

        //向Excel中写入表格的表头    
        int displayColumnsCount = 1;   
        for (int i = 0; i <= dgv.ColumnCount - 1; i++)   
        {   
            if (dgv.Columns[i].Visible == true)   
            {   
                objExcel.Cells[1, displayColumnsCount] = dgv.Columns[i].HeaderText.Trim();   
                displayColumnsCount++;   
            }   
        }   
        //设置进度条    
        //tempProgressBar.Refresh();    
        //tempProgressBar.Visible   =   true;    
        //tempProgressBar.Minimum=1;    
        //tempProgressBar.Maximum=dgv.RowCount;    
        //tempProgressBar.Step=1;    
        //向Excel中逐行逐列写入表格中的数据    
        for (int row = 0; row <= dgv.RowCount - 1; row++)   
        {   
            //tempProgressBar.PerformStep();    

            displayColumnsCount = 1;   
            for (int col = 0; col < colscount; col++)   
            {   
                if (dgv.Columns[col].Visible == true)   
                {   
                    try  
                    {   
                        objExcel.Cells[row + 2, displayColumnsCount] = dgv.Rows[row].Cells[col].Value.ToString().Trim();   
                        displayColumnsCount++;   
                    }   
                    catch (Exception)   
                    {   

                    }   

                }   
            }   
        }   
        //隐藏进度条    
        //tempProgressBar.Visible   =   false;    
        //保存文件    
        objWorkbook.SaveAs(fileNameString, Missing.Value, Missing.Value, Missing.Value, Missing.Value,   
                Missing.Value, Excel.XlSaveAsAccessMode.xlShared, Missing.Value, Missing.Value, Missing.Value,   
                Missing.Value, Missing.Value);   
    }   
    catch (Exception error)   
    {   
        MessageBox.Show(error.Message, "警告 ", MessageBoxButtons.OK, MessageBoxIcon.Warning);   
        return;   
    }   
    finally  
    {   
        //关闭Excel应用    
        if (objWorkbook != null) objWorkbook.Close(Missing.Value, Missing.Value, Missing.Value);   
        if (objExcel.Workbooks != null) objExcel.Workbooks.Close();   
        if (objExcel != null) objExcel.Quit();   

        objsheet = null;   
        objWorkbook = null;   
        objExcel = null;   
    }   
    MessageBox.Show(fileNameString + "\n\n导出完毕! ", "提示 ", MessageBoxButtons.OK, MessageBoxIcon.Information);   

}  

#endregion  

推荐阅读
  • 在使用SSHFS进行远程文件系统挂载时,经常遇到连接被对端重置的问题。经过详细排查,发现客户端使用的SSH版本与服务器端不兼容,导致连接失败。本文将深入分析该问题的原因,并提供多种解决方案,包括更新SSH客户端、调整SSH配置参数以及优化网络环境,以确保SSHFS连接的稳定性和可靠性。 ... [详细]
  • 探讨两种常数卷积的结果与一种常见的洗牌算法错误及其影响
    在编程中,随机打乱数组元素的顺序(即“洗牌”)是一个常见的需求。标准的洗牌算法是Fisher-Yates shuffle,但许多开发者在实现时容易犯错,导致结果不均匀。本文探讨了两种常数卷积的结果,并分析了一种常见的洗牌算法错误及其对随机性的影响。通过详细的实验和理论分析,我们揭示了这些错误的具体表现和潜在危害,为开发者提供改进的建议。 ... [详细]
  • 在软件开发领域,“池”技术被广泛应用,如数据库连接池、线程池等。本文重点探讨Java中的线程池ThreadPoolExecutor,通过详细解析其内部机制,帮助开发者理解如何高效利用线程池管理任务执行。线程池不仅能够显著减少系统资源的消耗,提高响应速度,还能通过合理的配置,如饱和策略,确保在高负载情况下系统的稳定性和可靠性。文章还将结合实际案例,展示线程池在不同应用场景下的具体实现与优化技巧。 ... [详细]
  • 本文深入剖析了ScheduledThreadPoolExecutor的并发执行机制及其源代码,详细解读了该线程池如何在指定延时或定期执行任务,探讨了其内部的工作原理和优化策略,为开发者提供了宝贵的参考和实践指导。 ... [详细]
  • RancherOS 是由 Rancher Labs 开发的一款专为 Docker 设计的轻量级 Linux 发行版,提供了一个全面的 Docker 运行环境。其引导镜像仅 20MB,非常适合在资源受限的环境中部署。本文将详细介绍如何在 ESXi 虚拟化平台上安装和配置 RancherOS,帮助用户快速搭建高效、稳定的容器化应用环境。 ... [详细]
  • 在 Python 中,魔法方法 `__dict__` 和 `__getattr__` 具有重要的作用和灵活的应用。`__dict__` 是一个用于存储对象属性的字典,其中键为属性名,值为对应的属性值。通过 `__dict__`,可以动态地访问和修改对象的属性。而 `__getattr__` 方法则在尝试访问对象中不存在的属性时被调用,提供了一种优雅的处理方式,避免了属性访问错误。这两个魔法方法在实现复杂的数据结构和动态行为时尤为有用。 ... [详细]
  • Windows环境下详细教程:如何搭建Git服务
    Windows环境下详细教程:如何搭建Git服务 ... [详细]
  • Typora快捷键使用指南:提升写作效率的必备技巧 ... [详细]
  • 在 Tomcat 上部署 Jenkins 实现持续集成环境搭建
    本文介绍了如何在Tomcat服务器上部署Jenkins以构建持续集成环境。首先,需下载并解压Tomcat压缩包,例如 `apache-tomcat-8.5.37.tar.gz`。接着,为Tomcat创建一个管理用户,并对相关文件目录进行权限配置,确保Jenkins能够顺利运行于Tomcat之上。此外,还详细阐述了环境配置、服务启动及基本的故障排查技巧,为用户提供了一套完整的部署指南。 ... [详细]
  • 对于内存仅为512MB、硬盘80GB的老旧设备,部署Ubuntu Server毫无压力。然而,许多平台仅支持CentOS系统,而CentOS默认要求1GB以上内存才能使用图形界面安装。实际上,安装完成后,即使内存低至256MB也能正常运行。此外,通过优化系统配置和减少不必要的服务,可以进一步提升系统性能,确保在资源受限的环境中稳定运行。 ... [详细]
  • 在Mesos上运行Spark时,常见的问题是Slave节点可能会因应用程序资源消耗过大而耗尽资源。本文分析了这一问题的成因,并提供了多种有效的解决方案,包括资源调度优化、任务分配策略调整以及系统配置改进等,帮助用户提升集群的稳定性和性能。 ... [详细]
  • 精通jQuery:深入解析事件处理机制与应用技巧
    本文详细探讨了jQuery的事件处理机制及其应用技巧,通过具体的代码示例,逐一解析了每个jQuery代码片段与其对应的HTML结构。文章以标记为基准,CSS作为通用样式,确保每段代码都能独立运行。HTML和CSS代码统一放置在文章末尾,方便读者参考和实践。 ... [详细]
  • 本文详细介绍了 Ansible Ad-Hoc 命令的使用方法,基于官方文档进行了中文翻译。Ad-Hoc 命令允许用户通过 `usr/bin/ansible` 快速执行一次性任务,适用于快速部署、配置管理和故障排查等场景。文中通过多个实例演示了 Ad-Hoc 命令的具体应用,帮助读者更好地理解和掌握这一强大工具。 ... [详细]
  • 本研究聚焦于利用Java、PHP和Python开发的汽车销售管理系统,旨在为计算机科学专业学生的毕业设计提供参考。项目采用BS架构,结合多种编程语言的优势,实现高效的数据管理和用户交互。该系统不仅涵盖了汽车销售的核心功能,还通过集成先进的技术栈,提升了系统的稳定性和扩展性。 ... [详细]
  • 本课程首先介绍了全栈开发的最后一公里为何重要,并详细探讨了搭建线上生产环境的关键步骤。随后,通过五个本地Node.js项目的实战演练,逐步展示了从快速构建纯静态简易站点到复杂应用的全过程,涵盖了环境配置、代码优化、性能调优等多方面内容。 ... [详细]
author-avatar
手机用户2602936797
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有