在VS2005中,将DataGridView中的数据导入Excel文件

 

/// <summary>
/// 将DataGridView中的数据导入Excel中,并显示Excel应用程序,

/// 注意调用该方法必须有安装Excel应用程序,并且假定DataGridView中绑定的是一个DataTable
/// </summary>
/// <param name="grid"></param>
/// <param name="ReportTitle"></param>


        
public   static   void  ExportDataGridToExcel(DataGridView grid,  string  ReportTitle)
        
{
            System.Data.DataTable myTable 
= (System.Data.DataTable)grid.DataSource;

            
try
            
{
                Microsoft.Office.Interop.Excel.Application xlApp 
= new Microsoft.Office.Interop.Excel.ApplicationClass();

                
int rowIndex;
                
int colIndex;

                rowIndex 
= 2;
                colIndex 
= 0;

                Microsoft.Office.Interop.Excel.Workbook xlBook 
= xlApp.Workbooks.Add(true);

                
if (grid.Rows.Count > 0)
                
{
                    Microsoft.Office.Interop.Excel.Range range 
= xlApp.get_Range(xlApp.Cells[11], xlApp.Cells[1, grid.Columns.Count]);
                    range.MergeCells 
= true;
                    xlApp.ActiveCell.FormulaR1C1 
= ReportTitle;
                    xlApp.ActiveCell.Font.Size 
= 18;
                    xlApp.ActiveCell.Font.Bold 
= true;

                    
foreach (DataGridViewColumn colu in grid.Columns)
                    
{
                        colIndex 
= colIndex + 1;
                        xlApp.Cells[
2, colIndex] = colu.HeaderText;
                    }


                    
//得到的表所有行,赋值给单元格

                    
for (int row = 0; row < myTable.Rows.Count; row++)
                    
{
                        rowIndex 
= rowIndex + 1;
                        colIndex 
= 0;
                        
for (int col = 0; col < grid.Columns.Count; col++)
                        
{
                            colIndex 
= colIndex + 1;
                            xlApp.Cells[rowIndex, colIndex] 
= grid.Rows[row].Cells[col].Value;
                        }

                    }

                }

                
else
                
{
                    Microsoft.Office.Interop.Excel.Range range 
= xlApp.get_Range(xlApp.Cells[11], xlApp.Cells[1, myTable.Columns.Count]);
                    range.MergeCells 
= true;
                    xlApp.ActiveCell.FormulaR1C1 
= ReportTitle;
                    xlApp.ActiveCell.Font.Size 
= 18;
                    xlApp.ActiveCell.Font.Bold 
= true;

                    
//将表中的栏位名称填到Excel的第一行

                    
foreach (DataColumn Col in myTable.Columns)
                    
{
                        colIndex 
= colIndex + 1;
                        xlApp.Cells[
2, colIndex] = Col.ColumnName;
                    }


                    
//得到的表所有行,赋值给单元格

                    
for (int row = 0; row < myTable.Rows.Count; row++)
                    
{
                        rowIndex 
= rowIndex + 1;
                        colIndex 
= 0;
                        
for (int col = 0; col < myTable.Columns.Count; col++)
                        
{
                            colIndex 
= colIndex + 1;
                            xlApp.Cells[rowIndex, colIndex] 
= grid.Rows[row].Cells[col].Value;
                        }

                    }

                }

                xlApp.get_Range(xlApp.Cells[
21], xlApp.Cells[2, colIndex]).Font.Bold = true;
                xlApp.get_Range(xlApp.Cells[
21], xlApp.Cells[rowIndex, colIndex]).Borders.LineStyle = 1;

                xlApp.Cells.EntireColumn.AutoFit();
                xlApp.Cells.VerticalAlignment 
= Microsoft.Office.Interop.Excel.Constants.xlCenter;
                xlApp.Cells.HorizontalAlignment 
= Microsoft.Office.Interop.Excel.Constants.xlCenter;
                xlApp.Visible 
= true;
            }

            
catch (Exception e)
            
{
                
throw e;
            }

            
        }

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值