この記事では、C#のさまざまなエクスポートメソッドの関連知識を主に紹介しており、参考価値があります。以下のエディターで見てみましょう
最初の方法: Microsoft.Office.Interop.Excel.dll
を使用します。まず、office の Excel をインストールし、次に Microsoft.Office.Interop を見つける必要があります。 Excel.dll コンポーネントが 参考資料 に追加されました。
public void ExportExcel(DataTable dt) { if (dt != null) { Microsoft.Office.Interop.Excel.Application excel = new Microsoft.Office.Interop.Excel.Application(); if (excel == null) { return; } //设置为不可见,操作在后台执行,为 true 的话会打开 Excel excel.Visible = false; //打开时设置为全屏显式 //excel.DisplayFullScreen = true; //初始化工作簿 Microsoft.Office.Interop.Excel.Workbooks workbooks = excel.Workbooks; //新增加一个工作簿,Add()方法也可以直接传入参数 true Microsoft.Office.Interop.Excel.Workbook workbook = workbooks.Add(Microsoft.Office.Interop.Excel.XlWBATemplate.xlWBATWorksheet); //同样是新增一个工作簿,但是会弹出保存对话框 //Microsoft.Office.Interop.Excel.Workbook workbook = excel.Application.Workbooks.Add(true); //新增加一个 Excel 表(sheet) Microsoft.Office.Interop.Excel.Worksheet worksheet = (Microsoft.Office.Interop.Excel.Worksheet)workbook.Worksheets[1]; //设置表的名称 worksheet.Name = dt.TableName; try { //创建一个单元格 Microsoft.Office.Interop.Excel.Range range; int rowIndex = 1; //行的起始下标为 1 int colIndex = 1; //列的起始下标为 1 //设置列名 for (int i = 0; i < dt.Columns.Count; i++) { //设置第一行,即列名 worksheet.Cells[rowIndex, colIndex + i] = dt.Columns[i].ColumnName; //获取第一行的每个单元格 range = worksheet.Cells[rowIndex, colIndex + i]; //设置单元格的内部颜色 range.Interior.ColorIndex = 33; //字体加粗 range.Font.Bold = true; //设置为黑色 range.Font.Color = 0; //设置为宋体 range.Font.Name = "Arial"; //设置字体大小 range.Font.Size = 12; //水平居中 range.HorizontalAlignment = Microsoft.Office.Interop.Excel.XlHAlign.xlHAlignCenter; //垂直居中 range.VerticalAlignment = Microsoft.Office.Interop.Excel.XlVAlign.xlVAlignCenter; } //跳过第一行,第一行写入了列名 rowIndex++; //写入数据 for (int i = 0; i < dt.Rows.Count; i++) { for (int j = 0; j < dt.Columns.Count; j++) { worksheet.Cells[rowIndex + i, colIndex + j] = dt.Rows[i][j].ToString(); } } //设置所有列宽为自动列宽 //worksheet.Columns.AutoFit(); //设置所有单元格列宽为自动列宽 worksheet.Cells.Columns.AutoFit(); //worksheet.Cells.EntireColumn.AutoFit(); //是否提示,如果想删除某个sheet页,首先要将此项设为fasle。 excel.DisplayAlerts = false; //保存写入的数据,这里还没有保存到磁盘 workbook.Saved = true; //设置导出文件路径 string path = HttpContext.Current.Server.MapPath("Export/"); //设置新建文件路径及名称 string savePath = path + DateTime.Now.ToString("yyyy-MM-dd-HH-mm-ss") + ".xlsx"; //创建文件 FileStream file = new FileStream(savePath, FileMode.CreateNew); //关闭释放流,不然没办法写入数据 file.Close(); file.Dispose(); //保存到指定的路径 workbook.SaveCopyAs(savePath); //还可以加入以下方法输出到浏览器下载 FileInfo fileInfo = new FileInfo(savePath); OutputClient(fileInfo); } catch(Exception ex) { } finally { workbook.Close(false, Type.Missing, Type.Missing); workbooks.Close(); //关闭退出 excel.Quit(); //释放 COM 对象 Marshal.ReleaseComObject(worksheet); Marshal.ReleaseComObject(workbook); Marshal.ReleaseComObject(workbooks); Marshal.ReleaseComObject(excel); worksheet = null; workbook = null; workbooks = null; excel = null; GC.Collect(); } } } public void OutputClient(FileInfo file) { HttpContext.Current.Response.Buffer = true; HttpContext.Current.Response.Clear(); HttpContext.Current.Response.ClearHeaders(); HttpContext.Current.Response.ClearContent(); HttpContext.Current.Response.ContentType = "application/vnd.ms-excel"; //导出到 .xlsx 格式不能用时,可以试试这个 //HttpContext.Current.Response.ContentType = "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet"; HttpContext.Current.Response.AddHeader("Content-Disposition", string.Format("attachment; filename={0}.xlsx", DateTime.Now.ToString("yyyy-MM-dd-HH-mm"))); HttpContext.Current.Response.Charset = "GB2312"; HttpContext.Current.Response.ContentEncoding = Encoding.GetEncoding("GB2312"); HttpContext.Current.Response.AddHeader("Content-Length", file.Length.ToString()); HttpContext.Current.Response.WriteFile(file.FullName); HttpContext.Current.Response.Flush(); HttpContext.Current.Response.Close(); }
最初の方法のパフォーマンスは本当にお世辞にも言えず、制限が多すぎます。まず、office をインストールする必要があります (コンピューター上にない場合)。また、エクスポート時にファイルを保存するパスを指定する必要があります。もちろん書き込んだデータが保存されていれば、ブラウザに出力してダウンロードすることも可能です。
2 番目: Aspose.Cells.dll を使用します
この Aspose.Cells は、Excel をエクスポートするために Aspose 社によって起動された コントロール であり、Office や商用ソフトウェアに依存せず、有料です。
public void ExportExcel(DataTable dt) { try { //获取指定虚拟路径的物理路径 string path = HttpContext.Current.Server.MapPath("DLL/") + "License.lic"; //读取 License 文件 Stream stream = (Stream)File.OpenRead(path); //注册 License Aspose.Cells.License li = new Aspose.Cells.License(); li.SetLicense(stream); //创建一个工作簿 Aspose.Cells.Workbook workbook = new Aspose.Cells.Workbook(); //创建一个 sheet 表 Aspose.Cells.Worksheet worksheet = workbook.Worksheets[0]; //设置 sheet 表名称 worksheet.Name = dt.TableName; Aspose.Cells.Cell cell; int rowIndex = 0; //行的起始下标为 0 int colIndex = 0; //列的起始下标为 0 //设置列名 for (int i = 0; i < dt.Columns.Count; i++) { //获取第一行的每个单元格 cell = worksheet.Cells[rowIndex, colIndex + i]; //设置列名 cell.PutValue(dt.Columns[i].ColumnName); //设置字体 cell.Style.Font.Name = "Arial"; //设置字体加粗 cell.Style.Font.IsBold = true; //设置字体大小 cell.Style.Font.Size = 12; //设置字体颜色 cell.Style.Font.Color = System.Drawing.Color.Black; //设置背景色 cell.Style.BackgroundColor = System.Drawing.Color.LightGreen; } //跳过第一行,第一行写入了列名 rowIndex++; //写入数据 for (int i = 0; i < dt.Rows.Count; i++) { for (int j = 0; j < dt.Columns.Count; j++) { cell = worksheet.Cells[rowIndex + i, colIndex + j]; cell.PutValue(dt.Rows[i][j]); } } //自动列宽 worksheet.AutoFitColumns(); //设置导出文件路径 path = HttpContext.Current.Server.MapPath("Export/"); //设置新建文件路径及名称 string savePath = path + DateTime.Now.ToString("yyyy-MM-dd-HH-mm-ss") + ".xlsx"; //创建文件 FileStream file = new FileStream(savePath, FileMode.CreateNew); //关闭释放流,不然没办法写入数据 file.Close(); file.Dispose(); //保存至指定路径 workbook.Save(savePath); //或者使用下面的方法,输出到浏览器下载。 //byte[] bytes = workbook.SaveToStream().ToArray(); //OutputClient(bytes); worksheet = null; workbook = null; } catch(Exception ex) { } } public void OutputClient(byte[] bytes) { HttpContext.Current.Response.Buffer = true; HttpContext.Current.Response.Clear(); HttpContext.Current.Response.ClearHeaders(); HttpContext.Current.Response.ClearContent(); HttpContext.Current.Response.ContentType = "application/vnd.ms-excel"; HttpContext.Current.Response.AddHeader("Content-Disposition", string.Format("attachment; filename={0}.xls", DateTime.Now.ToString("yyyy-MM-dd-HH-mm"))); HttpContext.Current.Response.Charset = "GB2312"; HttpContext.Current.Response.ContentEncoding = Encoding.GetEncoding("GB2312"); HttpContext.Current.Response.BinaryWrite(bytes); HttpContext.Current.Response.Flush(); HttpContext.Current.Response.Close(); }
2番目の方法はパフォーマンスが良く、操作は複雑ではありません。エクスポート時にファイルを保存するパスを設定でき、ストリームとして保存してブラウザに出力してダウンロードすることもできます。
3 番目のオプション: Microsoft.Jet.OLEDB
Excel を操作するこの方法は、データベースの操作に似ています。まず接続を紹介します 文字列:
// Excel 2003 版本连接字符串 string strConn = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=C:/xxx.xls;Extended Properties='Excel 8.0;HDR=Yes;IMEX=2;'"; // Excel 2007 以上版本连接字符串 string strConn = "Provider=Microsoft.ACE.OLEDB.12.0;Data Source=C:/xxx.xlsx;Extended Properties='Excel 12.0;HDR=Yes;IMEX=2;'";
プロバイダー: ドライバープログラム名
データソース: Excelファイルへのパスを指定します
拡張プロパティ: Excel 8.0 は Excel 2000 以降に対応し、Excel 12.0 は Excel 2007 以降に対応します。
HDR: Yes は、最初の行に列名が含まれており、行数の計算に最初の行は含まれないことを意味します。 NOは全く逆です。
IMEX: 0 書き込みモード、1 読み取りモード、2 読み取りおよび書き込みモード。エラーが「テーブルsheet1のデザインを変更できません。読み取り専用データベースにあります。」の場合は、これを削除すると問題は解決します。
以上がC# のさまざまなエクスポート方法の紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。