C#在客户端和服务端操作Excel文件
2007-05-07 16:55
441 查看
一、在客户端把数据导入到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" />
三、两种方法的优缺点
四、流输出
原理:把数据填充到 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();//结束
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();//结束
相关文章推荐
- C# TCP实现多个客户端与服务端 数据 与 文件的传输
- c#文件操作xml、ini、txt、excel、csv操作全解
- C#中对Excel文件的操作
- c# .Net :Excel NPOI导入导出操作教程之List集合的数据写到一个Excel文件并导出
- c# .Net :Excel NPOI导入导出操作教程之读取Excel文件信息及输出
- C#.net实现windows窗体程序对Excel文件的读写操作
- c# .Net :Excel NPOI导入导出操作教程之数据库表信息数据导出到一个Excel文件并写到磁盘示例分享
- B/s模式客户端无法操作EXCEL的文件解决
- C# TCP实现多个客户端与服务端 数据 与 文件的传输
- C#对word、excel、pdf等格式文件的操作总结
- C# 利用 OLEDB 操作 Excel 文件
- C#操作Excel文件~对已有的Excel文件操作
- Asp.net/c#+OleDb操作excel文件,基本操作 (一)
- Asp.net/c#+OleDb操作excel文件(二),数据传输使用Parameters
- C#对EXCEL文件操作
- C#中TCP实现多个客户端与服务端数据与文件的传输
- c# 导出Excel文件的操作示例
- C#对word、excel、pdf等格式文件的操作总结 .
- C# TCP实现多个客户端与服务端 数据 与 文件的传输
- C#将服务器端excel文件下载到客户端的简单方法