SpreadsheetControl的Api操作Excel

#region 填充Excel using (var spControl = new SpreadsheetControl()) { spControl.LoadDocument(tmpFilename); var wookBook = spControl.Document; var sheet = wookBook.Worksheets[cur.SheetName]; sheet.Range["A1:AZ60000"].Clear(); //填充标题 for (int i=0;i< dt.Columns.Count;i++) { var c=dt.Columns[i]; sheet.Cells[0, i].Value = c.ColumnName; } //填充内容 for (int i = 1; i < dt.Rows.Count; i++) { for (int j = 0; j < dt.Columns.Count; j++) { if (j == 0) { sheet.Cells[i, j].Value = dt.Rows[i][j].ToString(); } else { sheet.Cells[i, j].Value =(int) dt.Rows[i][j]; } } } spControl.SaveDocument(tmpFilename); } #endregion
using DevExpress.XtraSpreadsheet.Model;
using DevExpress.XtraSpreadsheet;
using DevExpress.Spreadsheet;

try { var cur=MainBindingSource.Current as Sys_Report; if (_SQLEnt == null) throw new Exception("报表必需先绑定查询"); sysSQLParamsBindingSource.EndEdit(); var paramList = sysSQLParamsBindingSource.DataSource as List<Sys_SQLParams>; var excelTemplateFile = @"c:\123Test.xls"; var ext = Path.GetExtension(excelTemplateFile); var tmpFilename = Path.Combine(Path.GetTempPath(), DateTime.Now.ToString("yyyyMMddhhmmss") + ext); Action act = () => { var ds = Fetch<ISys_SQLService>().ExecuteDataSet(_SQLEnt.SQLNo, paramList); var dt=ds.Tables[0]; File.Copy(excelTemplateFile, tmpFilename); //ExcelUtil.DataTable2Excel(tmpFilename, dt, cur.SheetName); Console.WriteLine(ds); }; InvokeService(act, "执行脚本..."); Process.Start(tmpFilename); } catch (Exception ex) { ErrMsg(ex.Message); }
直接拖Spreadsheetcontorl到form上会自动添加程序集的引用
-----------------------------------
生成时图标就没了,这个方案不行。
参考DevExpress带的Demo
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· [AI/GPT/综述] AI Agent的设计模式综述
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
2014-09-04 关于InvokeMethod Activity的异步调用
2012-09-04 .Net事件&委托备忘
2012-09-04 匿名委托注册事件的触发
2008-09-04 T-SQL 选择某一记录的前后相关记录