• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    .NET操作Excel实例分享

    1. 读取

    读取好像有几种方式,通过ADO.net, 通过Microsoft.Interop.Excel支持类库用调用COM读取,还有通过ZIP解压最终读取DOM(这个貌似蛮复杂)
    这里我用的ADO.NET只介绍这一个。

    复制代码 代码如下:

    public DataTable ExcelToDataTable(string strExcelPath, string strSheetName)
    {
      string strConn =
        "Provider=Microsoft.Jet.OLEDB.4.0;" + "Data Source=" + strExcelPath + ";" + "Extended Properties=Excel 5.0;";
      string strExcel = string.Format("select * from [{0}$]", strSheetName);
      DataSet ds = new DataSet();
      OleDbDataAdapter adapter = new OleDbDataAdapter(strExcel, strConn);
      adapter.Fill(ds, strSheetName);
      conn.Close();
      return ds.Tables[strSheetName];
    }

    参数: StrExcelPath Excel文件的路径,strSheetName 要读取表的名称
    这里贴个读SheetName的代码,这个是调用Microsoft.Interop.Excel来读取
        Excel.Workbook theWorkbook = ExcelObj.Workbooks.Open("Excel文件路径", 0, true, 5, "", "", true, Excel.XlPlatform.xlWindows, "\t", false, false, 0, true);
        Excel.Sheets sheets = theWorkbook.Worksheets;
        Excel.Worksheet worksheet = (Excel.Worksheet)sheets.get_Item(1);
        ExecName = worksheet.Name;
        theWorkbook.Close(null, null, null);//记得要关闭,否则程序关闭,Excel的进程还在
    2.创建新的excel文件

    复制代码 代码如下:

    Excel.ApplicationClass myExcel = new Excel.ApplicationClass();      //实例一个excel
    Excel._Workbook xBk;       //工作薄  相当于一个Excel文件                
    Excel._Worksheet xSt;      //工作Sheet    一个文件里的表
    xBk = myExcel.Workbooks.Add(true);      //允许添加 sheet
    object missing = System.Reflection.Missing.Value;//空值
    myExcel.Sheets.Add(missing, missing, 1, Excel.XlSheetType.xlWorksheet);//添加sheet
    xSt = (Excel._Worksheet)xBk.ActiveSheet;//得到默认sheet
    xSt.Name = "新的表";      //这里设置表名
    xBk.SaveAs( “保存路径” , missing, missing,
        missing, missing, missing, Excel.XlSaveAsAccessMode.xlShared,
        missing, missing, missing, missing);      //保存文件
    myExcel.Quit(); //同样要记得关闭

    3.添加内容
    这里只说一般数据的添加,图表的就不介绍了, 在Excel的操作里一般是以表格和范围为单位,行或列是从1开始而不是从0开始
    先介绍一下格式设置,如下
    如设置第一行字体为红色:((Excel.Range)xSt.Rows[1, Type.Missing]).Font.Color = 0xFF0000;      //xSt 是上边代码的变量名,颜色值是用16进制RGB
    设置第二列为百分数的格式 ((Excel.Range)xSt.Columns[2, Type.Missing]).NumberFormat = "0.00%";
          备常用格式:文本:@ 日期:yyyy/mm/dd  数字:#,##0.00  货币:¥#,##0.00  百分比:0.00%
    上边两种为行选择和列选择,如果要选择第1行第2列到第1行第5列就用get_Range();
          xSt.get_Range(xSt.Cells[1,2],xSt.Cells[1,5])
    如果需要其它格式,如单元格背景,边框,字体样式 ,查下文档。不过大部分从点出来的方法名就能知道了
    再就是添加内容,直接写点代码参考。

    复制代码 代码如下:

    int rowIdx = 2; //从第2行列始
    //这里dt 是DataTable数据源
    foreach( DataRow dr in dt.Rows )
    {
     int j = 1;      //从第1列开始
     myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString(); 
     myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString(); 
     myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString(); 
     myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString(); 
     myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString(); 
     myExcel.Cells[rowIdx, j++] = dr["dt列名"].ToString();
     //用公式的情况,显示A+B+C+D的结果
     myExcel.Cells[rowIdx, j++] = string.Format("=SUM(A{0}:D{0})",rowIdx);
     rowIdx++;
    }

    写完了save一下 xBk.Save(),还是记得要关闭。

    您可能感兴趣的文章:
    • Asp.Net 无刷新文件上传并显示进度条的实现方法及思路
    • VB.NET进度条的方法代码
    • asp.net(c#)开发中的文件上传组件uploadify的使用方法(带进度条)
    • asp.net 在客户端显示服务器端任务处理进度条的探讨
    • asp.net 生成静态页时的进度条显示
    • 利用Asp.Net回调机制实现进度条
    • asp.net web大文件上传带进度条实例代码
    • ASP.NET实现用图片进度条显示投票结果
    • ASP.NET技巧:教你制做Web实时进度条
    • asp.net导出excel数据的常见方法汇总
    • ASP.NET中上传并读取Excel文件数据示例
    • asp.net读取excel文件的三种方法示例
    • 进度条在.net导入Excel时的应用实例
    上一篇:aspx中的mysql操作类sqldatasource使用示例分享
    下一篇:asp.net利用存储过程实现模糊查询示例分享
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    .NET操作Excel实例分享 .NET,操作,Excel,实例,分享,