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表为:

 

转载于:https://www.cnblogs.com/wei325/p/5454493.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
c是计算机科学中的一个重要概念,代表着“条件语句”(Conditionals)。 条件语句是用来根据不同条件决定程序执行路径的一种结构。在计算机编程中,通过使用条件语句,我们可以根据不同的条件选择性地执行不同的代码块。 常见的条件语句有if语句和switch语句。if语句用于在满足某个条件时执行一段特定代码,如果条件不满足,则跳过这段代码。switch语句则根据表达式的值将控制转移到不同的代码块中。 条件语句的应用范围非常广泛。例如,在游戏开发中,我们可以根据玩家的得分来判断是否通过关卡或者获胜;在网页开发中,我们可以根据用户的操作决定是否显示某个元素;在数据分析中,我们可以根据不同的条件筛选数据等等。 使用条件语句可以让程序具有更多的灵活性和智能性。它使得程序能够根据不同的情况做出相应的反应,提高了程序的可靠性和可维护性。 然而,当条件语句的嵌套层次过多时,容易导致代码的复杂性增加,可读性下降。因此,在编程过程中,我们应该尽量简化条件语句的结构,避免过多的嵌套。同时,还可以使用更加高级的技术,如多态和设计模式来替代繁琐的条件语句,提高代码的可扩展性和可维护性。 总之,条件语句是计算机编程中不可或缺的一部分,它在程序中起着至关重要的作用。通过灵活运用条件语句,我们可以根据不同的条件来控制程序的行为,从而实现更复杂和智能的功能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值