随笔 - 81  文章 - 0  评论 - 514  阅读 - 41万

NPOI根据模板生成chart图表导出Excel

导入NPOI的全部dll。

因为NPOI的API里面还没有对于Chart图表方面的操作,所以只能根据提示做好的图表作为模板,修改数据源的方法来改变图表。

注意:NPOI要用2003版以下的excel才能更好的支持,对才2007版以上的,导出来图表会变形。

一、制作好一个excel模板

二、读取模板填充数据源

1.给NPOI扩展两个方法,以免下面代码中进行过多的判断

复制代码
 /// <summary>
    /// 扩展方法
    /// </summary>
  public static  class ExtFunction
    {
      public static ICell Cell(this IRow row,int index)
      {
          ICell cell = row.GetCell(index);
          if (cell == null)
          {
              cell = row.CreateCell(index);
          }
          return cell;
            
      }
      public static IRow Row(this ISheet sheet,int index)
      {
          IRow row = sheet.GetRow(index);
          if (row == null)
          {
              row = sheet.CreateRow(index);
          }
          return row;
      }
    }
复制代码

2.主要代码:

复制代码
  //导出excel
        private void btnExportExcel_Click(object sender, EventArgs e)
        {

            try
            {
                string filePath = string.Empty;
                HSSFWorkbook workbook = null;
                ISheet sheet1 = null;
                IRow row = null;
                int nowRowNum = 1;//当前行2,表头第一行
                if (diskInfos.Count < 1)
                {
                    MessageBox.Show("没有数据");
                    return;
                }
                //选择文件保存路径
                filePath = getFilePath();
                if (filePath == "")
                {
                    return;
                }
                //模板路径
                string excelTempPath = System.Environment.CurrentDirectory + "/temp.xls";
                //读取Excel模板
                using (FileStream fs = new FileStream(excelTempPath, FileMode.Open, FileAccess.Read))
                {
                    workbook = new HSSFWorkbook(fs);
                }
                //获取sheet1
                sheet1 = workbook.GetSheetAt(0);

                for (int i = 0; i < diskInfos.Count; i++)
                {
                    //获取当前行
                    row = sheet1.Row(nowRowNum);
                    //给行的单元格填充数据
                    row.Cell(0).SetCellValue(diskInfos[i].IP);
                    row.Cell(1).SetCellValue(diskInfos[i].DiskName);
                    row.Cell(2).SetCellValue(diskInfos[i].FreeSize);
                    row.Cell(3).SetCellValue(diskInfos[i].AllSize);
                    row.Cell(5).SetCellValue(diskInfos[i].Remark);
                    nowRowNum++;
                }

                //保存文件
                using (Stream stream = File.OpenWrite(filePath))
                {
                    workbook.Write(stream);
                }
                //弹出消息框
                MsgForm msgForm = new MsgForm(filePath);
                msgForm.ShowDialog();
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }

        }
        //弹出选择保存的路径
        public string getFilePath()
        {
            string filePath = "";
            SaveFileDialog sfd=new SaveFileDialog ();
            //文件类型限制
            sfd.Filter = "Files|*.xls";
            //默认文件名
            sfd.FileName = "DiskReport.xls";
            if (sfd.ShowDialog() == DialogResult.OK)
            {
                filePath = sfd.FileName;
            }

            return filePath;
        }
复制代码

 功能为查询公司几个服务器的磁盘使用情况,最后导出的excel表为:

 

posted on   包子wxl  阅读(6731)  评论(4编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
< 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

点击右上角即可分享
微信分享提示

喜欢请打赏

扫描二维码打赏

支付宝打赏