c# 访问excel

首先将excel.exe copy 到 ../Microsoft Visual Studio .NET
                        2003/SDK/v1.1/Bin目录下
                        利用.net 中带的工具在命令提示符下执行tlbimp
                        excel.exe.这样就不会因为你的Excel是xp或2000的不同要去找不同的*.olb文件,还有一点就是因为在2000以后的版本中没有了excel9.olb这个文件了。

                        通过执行tlbimp excel.exe后我们会得到excel.dll文件。

                        只要有了这个Excel.dll,现在我们就能使用Excel的各种操作函数了。

一点说明:操作Excel的时候,可能会发生Excel进程被锁定,无法退
出,解决方法是在保存完并关闭myBook(工作簿)后,别关闭Excel进
程(//myApp.Quit();)。这样的结果是服务器上始终有一个Excel的
进程。可能会出现asp_net用户操作Excel的权限不够,配置Dcom。运
行Dcomcnfg.exe,找到Excel应用程序,配置其属性,身份验证级别
选"无",身份标识选"交互式用户",安全性页面,启动和访问均给
everyone。注意:查看当前进程中是否有Winword进程存在,如果有且
不能被结束,那么重启动计算机。再次运行你的代码即OK。这样以后
就不会出现权限不够的情况了。


在Visual Studio .NET中建立一个C# WinForm工程.
添加Microsoft Excel Object Library引用:
右键单击Project , 选“添加引用”
在COM 标签项,选中 locate Microsoft Excel Object Library


using Excel = Microsoft.Office.Interop.Excel;
using System.Reflection;

Excel.Application excel= new Excel.Application();


    int rowIndex=1;
    int colIndex=0;

    excel.Application.Workbooks.Add(true);
           
   
    System.Data.DataTable table=ds.Tables[0] ;
    foreach(DataColumn col in table.Columns)
    {
     colIndex++;   
     excel.Cells[1,colIndex]=col.ColumnName;               
    }

    foreach(DataRow row in table.Rows)
    {
     rowIndex++;
     colIndex=0;
     foreach(DataColumn col in table.Columns)
     {
      colIndex++;
      excel.Cells[rowIndex,colIndex]=row[col.ColumnName].ToString();
     }
    }
    excel.Visible=false;   
  
    excel.ActiveWorkbook.SaveAs("C:/A.XLS",Excel.XlFileFormat.xlExcel9795,null,null,false,false,Excel.XlSaveAsAccessMode.xlNoChange,null,null,null,null,null);

           
           
    //wkbNew.SaveAs strBookName


    //excel.Save(strExcelFileName);
    excel.Quit();
    excel=null;
           
    GC.Collect();//垃圾回收


回收垃圾
public void KillWordProcess()
{
int ProceedingCount = 0;
try
{
System.Diagnostics.Process [] ProceddingCon = System.Diagnostics.Process.GetProcesses();
foreach(System.Diagnostics.Process IsProcedding in ProceddingCon)
{
if(IsProcedding.ProcessName.ToUpper() == "WINWORD")
{
ProceedingCount += 1;
IsProcedding.Kill();
}
}
}
catch(System.Exception err)
{
MessageBox.Show(err.Message + "/r" +"(" + err.Source + ")" + "/r" + err.StackTrace);
}
}
#endregion

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值