国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C# > 正文

C#實現DataSet內數據轉化為Excel和Word文件的通用類完整實例

2020-01-24 01:05:36
字體:
來源:轉載
供稿:網友

本文實例講述了C#實現DataSet內數據轉化為Excel和Word文件的通用類。分享給大家供大家參考,具體如下:

前不久因為項目的需要寫的一個C#把DataSet內數據轉化為Excel和Word文件的通用類,這些關于Excel、Word的導出方法,基本可以實現日常須要,其中有些方法可以把數據導出后 生成Xml格式,再導入數據庫!有些屏蔽內容沒有去掉,保留下來方便學習參考用之。 最后請引用Office相應COM組件,導出Excel對象的一個方法要調用其中的一些方法和屬性。

using System;using System.Collections;using System.ComponentModel;using System.Data;using System.Web;using System.Web.SessionState;using System.Web.UI;using System.Web.UI.WebControls;using System.Web.UI.HtmlControls;using System.IO;using System.Windows.Forms;using Microsoft.Office.Interop.Excel;using Microsoft.Office.Interop.Word;using Microsoft.Office.Core;using OWC=Microsoft.Office.Interop;using System.Reflection;using System.Text;namespace CaOnLine.ZWDB.DFObject{ /// <summary> /// ExportFiles 的摘要說明。 /// 作用:把DataSet數據集內數據轉化為Excel、Word文件 /// 描述:這些關于Excel、Word的導出方法,基本可以實現日常須要,其中有些方法可以把數據導出后 ///    生成Xml格式,再導入數據庫!有些屏蔽內容沒有去掉,保留下來方便學習參考用之。 /// 備注:請引用Office相應COM組件,導出Excel對象的一個方法要調用其中的一些方法和屬性。 /// </summary> public class ExportFiles { /// <summary> /// /// </summary> /// #region //構造函數 public ExportFiles() {  //  // TODO: 在此處添加構造函數邏輯  // } #endregion /// <summary> /// 調用Excel.dll導出Excel文件 /// </summary> /// <param name="ds"></param> /// #region // 調用Excel.dll導出Excel文件     /// <summary>     ///     /// </summary>     /// <param name="ds">DataSet數據庥</param>     /// <param name="Duser">登錄用戶(如session["username"].Tostring())可為null或空</param>     /// <param name="titlename">添加一個報表標題</param>     /// <param name="filepath">指定文件在服務器上的存放地址(如:Server.MapPath("."))可為null或空</param>     ///     /// 為什么在這里設置個filepath?     /// 原因如下:filepath接收的內容是Server.MapPath(".")這個參數值,這個值在這本類中對     /// System.Web.HttpServerUtility HServer=new System.Web.HttpServerUtility()的引用出錯,因為沒有繼承Page類     /// 所以只能以傳值的形式調用了,你有好的辦法可以修改,那就再好不過了! public void DataSetToExcel(DataSet ds,string Duser,string titlename,string filepath) {  //Microsoft.Office.Interop.Owc11() appowc=new Microsoft.Office.Interop.Owc11();  OWC.Owc11.SpreadsheetClass xlsheet=new Microsoft.Office.Interop.Owc11.SpreadsheetClass();  #region //屏蔽內容  ///本來想用下面的這個辦法實現的,可在IIS中必須設置相關的權限  ///所以就放棄了,把代碼設置為屏蔽內容,供學習參考!  /////  Microsoft.Office.Interop.Excel.Application app=new Microsoft.Office.Interop.Excel.Application();////  if(app==null)//  {//        throw new Exception("系統調用錯誤(Excel.dll)");//  }//  app.Application.Workbooks.Add(true);//  WorkbookClass oBook=new WorkbookClass();//      WorksheetClass oSheet=new WorksheetClass();////  //定義表對象與行對象,同時用DataSet對其值進行初始化//  System.Data.DataTable dt=ds.Tables[0];//   oSheet.get_Range(app.Cells[1,1],app.Cells[10,15]).HorizontalAlignment=OWC.Owc11.XlHAlign.xlHAlignCenter;//  DataRow[] myRow=dt.Select();//  int i=0;//  int cl=dt.Columns.Count;//  //取得數據表各列標題//  for(i=0;i<cl;i++)//  {//  app.Cells[1,i+1]=dt.Columns[i].Caption.ToString();//  //app.Cells.AddComment(dt.Columns[i].Caption.ToString());//  //oSheet.Cells.AddComment(dt.Columns[i].Caption.ToString());//  //app.Cells=dt.Columns[i].Caption.ToString();//  //oSheet.get_Range(app.Cells,app.Cells).HorizontalAlignment=//  //app.Cells.AddComment=dt.Columns[i].ToString();//  //oSheet.get_Range(app.Cells,app.Cells).HorizontalAlignment=//  }  #endregion  //定義表對象與行對象,同時用DataSet對其值進行初始化      System.Data.DataTable dt=ds.Tables[0];  DataRow[] myRow=dt.Select();      int i=0;  int col=1;  int colday=col+1;  int colsecond=colday+1;  int colnumber=colsecond+1;  int cl=dt.Columns.Count;  string userfile=null;  //合并單元格  xlsheet.get_Range(xlsheet.Cells[col,col],xlsheet.Cells[col,cl]).set_MergeCells(true);  //添加標題名稱  if(titlename=="" || titlename==null)    xlsheet.ActiveSheet.Cells[col,col]="添加標題處(高級報表)";  else  xlsheet.ActiveSheet.Cells[col,col]=titlename.Trim();      //判斷傳值user是否為空  if(Duser=="" || Duser==null)  userfile="DFSOFT";  else  userfile=Duser;  //設置標題大小  xlsheet.get_Range(xlsheet.Cells[col,col],xlsheet.Cells[col,cl]).Font.set_Size(13);  //加粗標題  xlsheet.get_Range(xlsheet.Cells[col,col],xlsheet.Cells[col,cl]).Font.set_Bold(true);   xlsheet.get_Range(xlsheet.Cells[colsecond,col],xlsheet.Cells[colsecond,cl]).Font.set_Bold(true);  //設置標題水平居中  xlsheet.get_Range(xlsheet.Cells,xlsheet.Cells).set_HorizontalAlignment(OWC.Owc11.XlHAlign.xlHAlignCenter);  //設置單元格寬度  //xlsheet.get_Range(xlsheet.Cells,xlsheet.Cells).set_ColumnWidth(9);  xlsheet.get_Range(xlsheet.Cells[colday,col],xlsheet.Cells[colday,cl]).set_MergeCells(true);  xlsheet.ActiveSheet.Cells[colday,col]="日期:"+DateTime.Now.Year.ToString()+"年"+DateTime.Now.Month.ToString()+"月"+DateTime.Now.Day.ToString()+"日 ";  xlsheet.get_Range(xlsheet.Cells[colday,col],xlsheet.Cells[colday,cl]).set_HorizontalAlignment(OWC.Owc11.XlHAlign.xlHAlignRight);  //取得數據表各列標題,各標題之間以/t分割,最后一個列標題后加回車符  for(i=0;i<cl;i++)  {  xlsheet.ActiveSheet.Cells[colsecond,i+1]=dt.Columns[i].Caption.ToString();  }      //逐行處理數據  foreach(DataRow row in myRow)  {  //當前數據寫入  for(i=0;i<cl;i++)  {   xlsheet.ActiveSheet.Cells[colnumber,i+1]=row[i].ToString().Trim();  }  colnumber++;  }  //設置邊框線  xlsheet.get_Range(xlsheet.Cells[colsecond,col],xlsheet.Cells[colnumber-1,cl]).Borders.set_LineStyle(OWC.Owc11.XlLineStyle.xlContinuous);  try  {  //xlsheet.get_Range(xlsheet.Cells[2,1],xlsheet.Cells[8,15]).set_NumberFormat("¥#,##0.00");  // System.Web.HttpServerUtility HServer=new System.Web.HttpServerUtility();  //HServer.MapPath(".")+"http://testowc.xls";  xlsheet.Export(filepath+"http://exportfiles//~$"+userfile+".xls",OWC.Owc11.SheetExportActionEnum.ssExportActionNone,OWC.Owc11.SheetExportFormat.ssExportXMLSpreadsheet);  }  catch(Exception e)  {  throw new Exception("系統調用錯誤或有打開的Excel文件!"+e);  }  //Web頁面定義  HttpResponse resp;  resp=HttpContext.Current.Response;  resp.ContentEncoding=System.Text.Encoding.GetEncoding("GB2312");  resp.AppendHeader("Content-disposition","attachment;filename="+userfile+".xls");  resp.ContentType="application/ms-excel";  string path=filepath+"http://exportfiles//~$"+userfile+".xls";  System.IO.FileInfo file = new FileInfo(path);  resp.Clear();  resp.AddHeader("content-length",file.Length.ToString());  resp.WriteFile(file.FullName);  resp.End(); } #endregion /// <summary> /// 導出Excel文件類 /// </summary> /// <param name="ds"></param> /// <param name="FileName"></param> /// #region //導出Excel文件類 public void DataSetToExcel(DataSet ds,string FileName) {  try  {  //Web頁面定義  //System.Web.UI.Page mypage=new System.Web.UI.Page();  HttpResponse resp;  resp=HttpContext.Current.Response;  resp.ContentEncoding=System.Text.Encoding.GetEncoding("GB2312");  resp.AppendHeader("Content-disposition","attachment;filename="+FileName+".xls");  resp.ContentType="application/ms-excel";  //變量定義  string colHeaders=null;  string Is_item=null;  //顯示格式定義////////////////  //文件流操作定義  // FileStream fs=new FileStream(FileName,FileMode.Create,FileAccess.Write);  //StreamWriter sw=new StreamWriter(fs,System.Text.Encoding.GetEncoding("GB2312"));  StringWriter sfw=new StringWriter();  //定義表對象與行對象,同時用DataSet對其值進行初始化  System.Data.DataTable dt=ds.Tables[0];  DataRow[] myRow=dt.Select();  int i=0;  int cl=dt.Columns.Count;  //取得數據表各列標題,各標題之間以/t分割,最后一個列標題后加回車符  for(i=0;i<cl;i++)  {   //if(i==(cl-1)) //最后一列,加/n   // colHeaders+=dt.Columns[i].Caption.ToString();   //else   colHeaders+=dt.Columns[i].Caption.ToString()+"/t";  }  sfw.WriteLine(colHeaders);  //sw.WriteLine(colHeaders);  //逐行處理數據  foreach(DataRow row in myRow)  {   //當前數據寫入   for(i=0;i<cl;i++)   {   //if(i==(cl-1))   //  Is_item+=row[i].ToString()+"/n";   //else   Is_item+=row[i].ToString()+"/t";   }   sfw.WriteLine(Is_item);   //sw.WriteLine(Is_item);   Is_item=null;  }  resp.Write(sfw);  //resp.Clear();  resp.End();  }  catch(Exception e)  {        throw e;  } } #endregion /// <summary> /// 數據集轉換,即把DataSet轉換為Excel對象 /// </summary> /// <param name="ds"></param> /// <param name="FileName"></param> /// <param name="titlename"></param> /// #region   //運用html+css生成Excel public void DataSetToExcel(DataSet ds,String FileName,string titlename) {  string ExportFileName=null;  if(FileName==null || FileName=="")  ExportFileName="DFSOFT";  else  ExportFileName=FileName;  if(titlename=="" || titlename==null)  titlename="添加標題處(高級報表)";  //定義表對象與行對象,同時用DataSet對其值進行初始化  System.Data.DataTable dt=ds.Tables[0];  DataRow[] myRow=dt.Select();  int i=0;  int cl=dt.Columns.Count;  //Web頁面定義  HttpResponse resp;  resp=HttpContext.Current.Response;  resp.Clear();  resp.ContentEncoding=System.Text.Encoding.GetEncoding("utf-8");  resp.AppendHeader("Content-disposition","attachment;filename="+ExportFileName+".xls");  resp.ContentType="application/vnd.ms-excel";  string BeginTab="<table border='0' cellpadding='0' cellspacing='0' style='border-right:#000000 0.1pt solid;border-top:#000000 0.1pt solid;'>";  string EndTab="</table>";  string FileIO=null;  string MainIO=null;  string TitleTab="<tr><td colspan='"+cl+"' style='font-size:30px;' align='center'><b>"+titlename+"</b></td></tr><tr><td colspan='"+cl+"' align='right' style='font-size:15px;'>"+DateTime.Now.Year.ToString()+"年"+DateTime.Now.Month.ToString()+"月"+DateTime.Now.Day.ToString()+"日    </td></tr>";  string BeginTr="<tr>";  string EndTr="</tr>";  for(i=0;i<cl;i++)  {  FileIO+="<td style='border-left:#000000 0.1pt solid; border-bottom:#000000 1.0pt solid; font-size:15px;' align='center'><b>"+dt.Columns[i].Caption.ToString()+"</b></td>";  }  FileIO=BeginTr.ToString()+FileIO.ToString()+EndTr.ToString();  //逐行處理數據  foreach(DataRow row in myRow)  {  string OutIO=null;  //當前數據寫入  for(i=0;i<cl;i++)  {   OutIO+="<td style='border-left:#000000 0.1pt solid; border-bottom:#000000 1.0pt solid; font-size:15px;' align='center'>"+row[i].ToString()+"</td>";  }  MainIO+=BeginTr.ToString()+OutIO.ToString()+EndTr.ToString();  }  FileIO="<center><table>"+TitleTab.ToString()+"<tr>"+BeginTab.ToString()+FileIO.ToString()+MainIO.ToString()+EndTab.ToString()+"</tr></table></center>";  resp.Write(FileIO.ToString());  resp.End(); } #endregion /// <summary> /// 導出Word文件類 /// </summary> /// <param name="ds"></param> /// <param name="FileName"></param> /// #region //導出Word文件類 public void DataSetToWord(DataSet ds,string FileName) {  try  {  //Web頁面定義  //System.Web.UI.Page mypage=new System.Web.UI.Page();  HttpResponse resp;  resp=HttpContext.Current.Response;  resp.Clear();  resp.Buffer=true;  resp.Charset="utf-8";  resp.ContentEncoding=System.Text.Encoding.GetEncoding("utf-8");  resp.AppendHeader("Content-disposition","attachment;filename="+FileName+".doc");  resp.ContentType="application/ms-word";  //變量定義  string colHeaders=null;  string Is_item=null;  //顯示格式定義////////////////  //文件流操作定義  // FileStream fs=new FileStream(FileName,FileMode.Create,FileAccess.Write);  //StreamWriter sw=new StreamWriter(fs,System.Text.Encoding.GetEncoding("GB2312"));  StringWriter sfw=new StringWriter();  //定義表對象與行對象,同時用DataSet對其值進行初始化  System.Data.DataTable dt=ds.Tables[0];  DataRow[] myRow=dt.Select();  int i=0;  int cl=dt.Columns.Count;  //取得數據表各列標題,各標題之間以/t分割,最后一個列標題后加回車符  for(i=0;i<cl;i++)  {   //if(i==(cl-1)) //最后一列,加/n   // colHeaders+=dt.Columns[i].Caption.ToString();   //else   colHeaders+=dt.Columns[i].Caption.ToString()+"/t";  }  sfw.WriteLine(colHeaders);  //sw.WriteLine(colHeaders);  //逐行處理數據  foreach(DataRow row in myRow)  {   //當前數據寫入   for(i=0;i<cl;i++)   {   //if(i==(cl-1))   //  Is_item+=row[i].ToString()+"/n";   //else   Is_item+=row[i].ToString()+"/t";   }   sfw.WriteLine(Is_item);   //sw.WriteLine(Is_item);   Is_item=null;  }  resp.Write(sfw);  //resp.Clear();  resp.End();  }  catch(Exception e)  {  throw e;  } } #endregion /// <summary> /// 數據集轉換,即把DataSet轉換為Word對象 /// </summary> /// <param name="ds"></param> /// <param name="titlename"></param> /// #region // 運行html+css生成Word文件 public void DataSetToWord(DataSet ds,string FileName,string titlename) {  //調用Office  //備注:速度太慢放棄應用此方法  //OWC.Word.Application oWord=new OWC.Word.ApplicationClass();  //OWC.Word._Document oDoc=new OWC.Word.DocumentClass();  string ExportFileName=null;  if(FileName==null || FileName=="")  ExportFileName="DFSOFT";  else  ExportFileName=FileName;  if(titlename=="" || titlename==null)  titlename="添加標題處(高級報表)";  //定義表對象與行對象,同時用DataSet對其值進行初始化  System.Data.DataTable dt=ds.Tables[0];  DataRow[] myRow=dt.Select();  int i=0;  int cl=dt.Columns.Count;  #region//  string FileTitle="<center><table><tr><td><b>報表測試</b></td></tr></table>"+"/n";//  string EndFile="</center>";//  //Web頁面定義  HttpResponse resp;  resp=HttpContext.Current.Response;  resp.Clear();  resp.ContentEncoding=System.Text.Encoding.GetEncoding("utf-8");  resp.AppendHeader("Content-disposition","attachment;filename="+ExportFileName+".doc");  resp.ContentType="application/vnd.ms-word";//  System.IO.StringWriter oSW=new StringWriter();//   System.Web.UI.HtmlTextWriter oHW=new System.Web.UI.HtmlTextWriter(oSW);//  System.Web.UI.WebControls.DataGrid oDG=new System.Web.UI.WebControls.DataGrid();//      oDG.DataSource=ds.Tables[0];//  oDG.DataBind();//  oDG.RenderControl(oHW);//  resp.Write(FileTitle.ToString()+oSW.ToString()+EndFile.ToString());//  resp.End();  #endregion  string BeginTab="<table border='0' cellpadding='0' cellspacing='0' style='border-right:#000000 0.1pt solid;border-top:#000000 0.1pt solid;'>";  string EndTab="</table>";  string FileIO=null;  string MainIO=null;  string TitleTab="<tr><td style='font-size:13px;' align='center'><b>"+titlename+"</b></td></tr><tr><td align='right' style='font-size:15px;'>"+DateTime.Now.Year.ToString()+"年"+DateTime.Now.Month.ToString()+"月"+DateTime.Now.Day.ToString()+"日    </td></tr>";  string BeginTr="<tr>";  string EndTr="</tr>";  for(i=0;i<cl;i++)  {  FileIO+="<td style='border-left:#000000 0.1pt solid; border-bottom:#000000 1.0pt solid; font-size:15px;' align='center'><b>"+dt.Columns[i].Caption.ToString()+"</b></td>";  }  FileIO=BeginTr.ToString()+FileIO.ToString()+EndTr.ToString();  //逐行處理數據  foreach(DataRow row in myRow)  {  string OutIO=null;  //當前數據寫入  for(i=0;i<cl;i++)  {   OutIO+="<td style='border-left:#000000 0.1pt solid; border-bottom:#000000 1.0pt solid; font-size:15px;' align='center'>"+row[i].ToString()+"</td>";  }  MainIO+=BeginTr.ToString()+OutIO.ToString()+EndTr.ToString();  }  FileIO="<center><table>"+TitleTab.ToString()+"<tr>"+BeginTab.ToString()+FileIO.ToString()+MainIO.ToString()+EndTab.ToString()+"</tr></table></center>";  resp.Write(FileIO.ToString());  resp.End(); } #endregion }}

更多關于C#相關內容感興趣的讀者可查看本站專題:《C#操作Excel技巧總結》、《C#中XML文件操作技巧匯總》、《C#常見控件用法教程》、《WinForm控件用法總結》、《C#數據結構與算法教程》、《C#面向對象程序設計入門教程》及《C#程序設計之線程使用技巧總結

希望本文所述對大家C#程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 视频| 金乡县| 贞丰县| 芦山县| 屏边| 新昌县| 社会| 连江县| 独山县| 葫芦岛市| 维西| 阆中市| 内乡县| 张家口市| 莒南县| 西青区| 项城市| 永善县| 灵丘县| 黎城县| 会昌县| 韶关市| 姜堰市| 灌南县| 高密市| 酒泉市| 浮梁县| 英吉沙县| 昆山市| 安泽县| 禹城市| 灌云县| 日照市| 铜川市| 山东省| 磐石市| 文山县| 甘肃省| 额济纳旗| 积石山| 靖远县|