分享
 
 
 

C#在客戶端和服務端操作Excel文件

王朝c#·作者佚名  2006-01-31
窄屏简体版  字體: |||超大  

一、在客戶端把數據導入到Excel文件步驟

1、創建Excel application對象,打開或生成Excel文件

//服務端創建StringBuilder對象

System.Text.StringBuilder sb=new System .Text .StringBuilder ();

//指定客戶端執行語言

sb.Append ("<Script Language=VBScript>");

sb.Append ("<!--\r\n");

sb.Append ("dim xls\r\n");

//創建Excel application對象

sb.Append ("Set xls=CreateObject(\"Excel.Application\")\r\n");

//打開Excel文件

sb.Append ("xls.WorkBooks.Open(C:\\MyExcel.xls)\r\n");

2、選定工作表,把數據導入到Excel

//選定欲操作的Excel表

sb.Append ("xls.Sheets(1).Select\r\n");

//获得要操作数据表的行、列数

int rows=dt.Rows.Count,cols=dt.Columns.Count ;

//按行列将数据写入Excel表

for (int j=brow+1;j<brow+cols ;j++)

for (int i=bcol;i<bcol+rows ;i++)

sb.Append ("xls.Sheets(1).Cells(" +(j-1) + "," + (i) + ")=\"" + dt.Rows[i-bcol][j-brow].ToString ().Replace ("\"","'") + "\"\r\n");

3、显示Excel文件

sb.Append ("xls.visible=true\r\n");

4、釋放創建的Excel application對象

sb.Append ("set xls=nothing\r\n");

sb.Append ("-->");

sb.Append ("</script>");

5、將代碼寫到客戶端

this.Page.RegisterClientScriptBlock("",sb.ToString ());

二、在服務端操作Excel文件

服務端操作Excel文件,是把Excel文件看作數據庫,把Excel工作表當作數據表

1、創建連接並打開連接

protected System.Data .OleDb.OleDbConnection dbcnn;

cnnstr="Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=\"Excel 8.0;HDR=Yes;\";Data Source=C:\\MyExcel.xls”;

dbcnn=new OleDbConnection (cnnstr);

dbcnn.Open ();

2、創建OleDbCommand對象用來操作Excel文件

protected System.Data .OleDb .OleDbCommand dbcmd;

dbcmd=new OleDbCommand();

dbcmd.Connection =dbcnn;

3、操作Excel文件

//获得要操作数据表的行、列数

rows=dt.Rows.Count ;

cols=dt.Columns.Count-1 ;

//按行列将数据写入Excel文件Sheet1工作表

for(int i=0;i<rows;i++)

{

olestr=" insert into [Sheet1$] values(";

for(int j=0;j<cols;j++)

olestr=olestr+"'"+dt.Rows[i][j].ToString ()+"',";

olestr+="'"+Convert.ToDecimal (dt.Rows[i][cols].ToString ())+"')";

dbcmd.CommandText =olestr;

dbcmd.ExecuteNonQuery ();

}

4、釋放OleDbCommand對象、關閉連接

dbcmd.Dispose ();

dbcnn.Close ();

5、可操作的SQL語句

//建立名為punchdate的工作表,並指明子段類型。

//創建工作表好處是可指定子段類型,否則都以字符串導出

CREATE TABLE punchdate(mno char(5), punchNum float)

//插入新數據

Insert into punchdate(mno,punchNum) values(‘09’,9000)

//更新數據

Update punchdate set punchNum=8000 where mno=’09’

6、不可操作的SQL語句

Delete from punchdate

7、注意連接子串

//HDR=Yes 説明工作表第一行為子段名

"Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=\"Excel 8.0;HDR=Yes;\";Data Source=C:\\MyExcel.xls”

//HDR=No 説明工作表沒有含子段名的行

"Provider=Microsoft.Jet.OLEDB.4.0;Extended Properties=\"Excel 8.0;HDR=No;\";Data Source=C:\\MyExcel.xls”

8、注意對Web.config的設置

刪除以下項目

<identity impersonate="true" />

或者這樣設置

<identity impersonate="false" />

三、兩種方法的優缺點

操作Excel文件方法

優點

缺點

客戶端

數據導入到Excel文件時,很靈活,可將數據填入任意指定的存儲格,定位到任意位置

1、在客戶端生成ActiveX控件,要將站點設置成可信站點或對IE進行安全設置(降低了IE的安全性)

2、對調用的Excel模板文件,用戶要有權讀寫

3、在客戶端寫Excel文件速度比較慢

服務端

1、對調用的Excel模板文件,只要ASP.NET有權讀寫即可

2、在服務端寫Excel文件速度比較快

3、不要對IE進行特別設置

對操作的文件只能當作數據庫操作,不夠靈活

四、流输出

原理:把數據填充到 DataGrid,然後把DataGrid内容放到一個輸出流裏面,並指定輸出流類型為 Excel

System.IO .StringWriter sw =new System.IO.StringWriter();//字符串流

System.Web .UI .HtmlTextWriter hw =new System.Web.UI.HtmlTextWriter(sw);//html 流,用字符串流作參數

dg.RenderControl(hw);//把DataGrid 流變成字符串流。

Response.ContentType ="application/vnd.ms-excel";//定義輸出流類型為 excel 流。關鍵語句。

Response.ContentEncoding=System.Text.Encoding.GetEncoding("Big5");//指定編碼類型為大五碼

Response.Write(sw.ToString());//輸出流

Response.End();//結束

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有