MyXls组件操作Excel报表(C#)

    在后台调用 excel 组件,生成 Excel ,虽然可以 Excel 文件 进行 完全控制, 可以生成任何复杂的格式,但是有个很大的缺点,这种方式会产生很多 Excel进程 很难完全清 掉,特别是在出错的时候, 可能会使整个服务器崩溃。本文为大家介绍一个 C# 写的开源组件,并简单说下 office2003 和以上版本支持的 XML 格式。

 操作Excel二进制格式

    OpenOffice.org发布过的俩个文档Excel File Format (BIFF8)SpecificationMicrosoft CompoundDocument (OLE2) Format SpecificationExcel的二进制格式做了一个比较详细的说明,依靠这些信息,我们可以直接操作Office二进制格式文档。

  MyXls是一个C#写的开源组件,可以用来生成具有很多表格且包含格式的Excel文件。它提供了一套基于对象的API,非常容易使用。

MyXls这个组件的DLL 和代码 可以在这下载到:
http://sourceforge.net/project/showfiles.php?group_id=205384&package_id=245371
以下是一个事例子。。

using  System;
using  System.Data;
using  System.Configuration;
using  System.Collections;
using  System.Web;
using  System.Web.Security;
using  System.Web.UI;
using  System.Web.UI.WebControls;
using  System.Web.UI.WebControls.WebParts;
using  System.Web.UI.HtmlControls;
using  org.in2bits.MyXls;

namespace  WebApplication1
{
    
public   partial   class  _Default : System.Web.UI.Page
    {
        
protected   void  Page_Load( object  sender, EventArgs e)
        {
            
        }

        
protected   void  Button1_Click( object  sender, EventArgs e)
        {
            XlsDocument xls 
=   new  XlsDocument();

            Worksheet sheet 
=  xls.Workbook.Worksheets.Add( " sheet " ); // 状态栏标题名称
            Cells cells  =  sheet.Cells;

            cells.Add(
1 1 " Name " );
            cells.Add(
1 2 " Age " );
            cells.Add(
1 3 " Email " );
            cells.Add(
1 4 " Description " );

            
for  ( int  i  =   0 ; i  <   5000 ; i ++ )
            {
                cells.Add(i 
+   2 1 " netflu " );
                cells.Add(i 
+   2 2 28 .ToString());
                cells.Add(i 
+   2 3 " xxx@163.com " );
                cells.Add(i 
+   2 4 " sheet.Cells.AddValueCell(rowIndex, colIndex, row[col.ColumnName].ToString());//将数据添加到xls表格里 " );
            }

            
// foreach (DataRow row in table.Rows)
            
// {
            
//     rowIndex++;
            
//     colIndex = 0;
            
//     foreach (DataColumn col in table.Columns)
            
//     {
            
//         colIndex++;
            
//          // sheet.Cells.AddValueCell(rowIndex, colIndex, row[col.ColumnName].ToString()); // 将数据添加到xls表格里
            
//         Cell cell = cells.AddValueCell(rowIndex, colIndex, Convert.ToDouble(row[col.ColumnName].ToString())); // 转换为数字型
            
//          // 如果你数据库里的数据都是数字的话 最好转换一下,不然导入到Excel里是以字符串形式显示。
            
//         cell.Font.FontFamily = FontFamilies.Roman;  // 字体
            
//         cell.Font.Bold = true;   // 字体为粗体            
            
//     }
            
// }
            xls.Send();
        }

    }
}

 

 

转载于:https://www.cnblogs.com/netflu/archive/2010/02/12/1667861.html

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值