遗忘海岸

江湖程序员 -Feiph(LM战士)

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

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
View Code
复制代码

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);
            }
View Code
复制代码

 

直接拖Spreadsheetcontorl到form上会自动添加程序集的引用

-----------------------------------

生成时图标就没了,这个方案不行。

参考DevExpress带的Demo

posted on   遗忘海岸  阅读(595)  评论(0编辑  收藏  举报

编辑推荐:
· 如何编写易于单元测试的代码
· 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 选择某一记录的前后相关记录
点击右上角即可分享
微信分享提示