1.  前言

  这是我最近项目刚要的需求,然后在网上找了半天的教材  但是很不幸,有关于Epplus的介绍真的太少了,然后经过了我的不断研究然后不断的采坑,知道现在看到Excel都想吐的时候,终于成功的完成了公司的要求,最后我 稍微的优化了一下代码(毕竟是个刚工作一年多的新人),现在就给大家看一看不足之处,希望给为大佬给以指点,稍后在后面我会给出项目下载。

//首页执行
DataTable dt = DBhelper.gettable();
List<RangeData> rlist=new List<RangeData>();
RangeData rd = new RangeData();
rd.Charttype = "ColumnStacked";
rd.Yaxis = "E6,G6,O6";
rd.UserName = "测试名称";
rd.Region = "测试地址";
rd.ChartName = "测试名称";
rd.ChartKeyword = "F36";
rd.Appointedtime = DateTime.Now.ToString();
rlist.Add(rd);
RangeData rd1 = new RangeData();
rd1.Charttype = "ColumnClustered";
rd1.Yaxis = "E6,G6,O6";
rd1.UserName = "测试名称1";
rd1.Region = "测试地址1";
rd1.ChartName = "测试名称1";
rd1.ChartKeyword = "F36";
rd1.Appointedtime = DateTime.Now.ToString();
rlist.Add(rd1);
RangeData rd2 = new RangeData();
rd2.Charttype = "Pie";
rd2.Yaxis = "E6,G6,O6";
rd2.UserName = "测试名称2";
rd2.Region = "测试地址2";
rd2.ChartName = "测试名称2";
rd2.ChartKeyword = "F36";
rd2.Appointedtime = DateTime.Now.ToString();
rlist.Add(rd2);
RangeData rd3 = new RangeData();
rd3.Charttype = "singleColumnClustered";
rd3.Yaxis = "E6,G6,O6";
rd3.UserName = "测试名称23";
rd3.Region = "测试地址23";
rd3.ChartName = "测试名称3";
rd3.ChartKeyword = "F36";
rd3.Appointedtime = DateTime.Now.ToString();
rlist.Add(rd3);
ExcelInfo.ExportClient("", dt, rlist);

public class ExcelInfo
{

      /// <summary>
/// 输出Excel文件
/// </summary>
/// <param name="FileName"></param>
/// <param name="table"></param>
/// <param name="?"></param>
public static void ExportClient(string FileName, DataTable table, List<RangeData> Rlist)
{
//reportTitle = "Microsoft,IBM,Oracle,Google.Yahoo";
FileName = FileName+DateTime.Now.ToString("yyyy_MM_dd_HHmmss") + ".xlsx";
// string TJcell = "D6,F6,H6,AJ6";
if (Directory.Exists("UpFiles"))
{
}
else
{
DirectoryInfo directoryInfo = new DirectoryInfo("UpFiles");
directoryInfo.Create();
}
FileInfo file = new FileInfo(@"D:\文档资料\自学项目\EpplusExcelChartWeb\EpplusExcelChartWeb\upfiles\" + FileName);
createExcel(file, table, Rlist); }
/// <summary>
/// 创建Excel Sheet
/// </summary>
/// <param name="file"></param>
public static void createExcel(FileInfo file, DataTable table, List<RangeData> Rlist)
{
ExcelPackage package = new ExcelPackage(new FileStream(@"D:\文档资料\自学项目\EpplusExcelChartWeb\EpplusExcelChartWeb\test1.xlsx", FileMode.Open));
ExcelWorksheet sheet = null;
sheet = package.Workbook.Worksheets[]; #region 设置Excel数据
SheetData(table, sheet);
#endregion
//设置图形
if (Rlist.Count > )
{
ExcelWorksheet sheet1 = null;
sheet1 = package.Workbook.Worksheets.Add("Data"); for (int i = ; i < Rlist.Count; i++)
{
SheetData(table, sheet1);
sheet.Cells["C3"].Value = Rlist[i].UserName;
sheet.Cells["C4"].Value = Rlist[i].Region;
sheet.Cells["O4"].Value = Rlist[i].Appointedtime;
if (Rlist[i].Charttype == "ColumnStacked")
{
//堆积柱形图
ColumnStacked(table, sheet, Rlist[i].Yaxis, Rlist[i].ChartName,Rlist[i].ChartKeyword);
}
else if (Rlist[i].Charttype == "ColumnClustered")
{
//簇状柱形图
ColumnClustered(table, sheet, Rlist[i].Yaxis, Rlist[i].ChartName, Rlist[i].ChartKeyword);
}
else if (Rlist[i].Charttype == "Pie")
{
//饼图
Pie(table, sheet, Rlist[i].Yaxis, Rlist[i].ChartName, Rlist[i].ChartKeyword);
}
else if (Rlist[i].Charttype == "singleColumnClustered")
{
singleColumnClustered(table, sheet, Rlist[i].Yaxis, Rlist[i].ChartName, Rlist[i].ChartKeyword);
}
}
}
else
{
System.Web.HttpContext.Current.Response.Write("<script language=javascript>alert('没有数据')</script>");
}
package.SaveAs(file);//保存文件
}
//工作簿数据
private static void SheetData(DataTable table, ExcelWorksheet sheet)
{
//if (cols[0] != "")
//{
// //设置列标题
// for (int col = 1; col <= cols.Length; col++)
// {
// sheet.Cells[1, col].Value = cols[col - 1];
// }
//}
//else
//{
//设置列标题
//for (int col = 1; col <= table.Columns.Count; col++)
//{
// sheet.Cells[1, col].Value = table.Columns[col - 1].ColumnName;
//}
//}
//设置数据
for (int row = ; row < table.Rows.Count; row++)
{
for (int col = ; col < table.Columns.Count; col++)
{
string range = sheet.MergedCells[row + , col + ];
string strvalue = table.Rows[row][col].ToString();
// sheet.Cells[row + 1, col].Style.Numberformat.Format = "#0\\.00%";//设置数据的格式为百分比
if (table.Rows[row]["F36"].ToString() != "")
{
sheet.Cells[row + , col + ].Style.Fill.PatternType = ExcelFillStyle.Solid;
sheet.Cells[row + , col + ].Style.Fill.BackgroundColor.SetColor(Color.Gray);
sheet.Cells[row + , col + ].Value = strvalue;
}
sheet.Cells[row + , col + ].Value = strvalue; }
}
}
/// <summary>
/// 堆积柱形图
/// </summary>
private static void ColumnStacked(DataTable table,ExcelWorksheet sheet, string TJCell,string Chartname,string ChartKeyword)
{
////图表系列
ExcelChartSerie chartSerie = null;
//图表
ExcelChart chart = null;
chart = sheet.Drawings.AddChart(Chartname, eChartType.ColumnStacked);
chart.Legend.Position = eLegendPosition.Right;
chart.Legend.Add();
chart.SetSize(, );//设置图表大小
chart.ShowHiddenData = true;
#region 规定单元格生成图表
string[] TJcellarray = TJCell.Split(',');
string XAxis = string.Empty;
string YAxis = string.Empty;
for (int row = ; row <= table.Rows.Count; row++)
{
if (table.Rows[row - ][ChartKeyword].ToString() != "")
{
for (int j = ; j < TJcellarray.Length; j++)
{
XAxis += "Data!" + GetEXcelstr(TJcellarray[j]) + (row + ) + ",";
YAxis += "test!" + TJcellarray[j] + ",";
}
int Xlength = XAxis.Length;
int Ylength = YAxis.Length;
XAxis = XAxis.Substring(, Xlength - );
YAxis = YAxis.Substring(, Ylength - );
chartSerie = chart.Series.Add(XAxis, YAxis);
chartSerie.HeaderAddress = sheet.Cells[row + , ];//设置每条线的名称
XAxis = "";
YAxis = "";
}
}
#endregion
// chartSerie = ChartData(table, cell, sheet, chartSerie, chart, TJcell,"F36");
chart.SetPosition(table.Rows.Count + , , , );//设置图表位置
}
/// <summary>
/// 多条簇状柱形图
/// </summary>
private static void ColumnClustered(DataTable table, ExcelWorksheet sheet, string TJCell, string Chartname, string ChartKeyword)
{
////图表系列
ExcelChartSerie chartSerie = null;
//图表
ExcelChart chart = null;
chart = sheet.Drawings.AddChart(Chartname, eChartType.ColumnClustered);
chart.Legend.Position = eLegendPosition.Right;
chart.Legend.Add();
chart.SetSize(, );//设置图表大小
chart.ShowHiddenData = true;
#region 规定单元格生成图表
string[] TJcellarray = TJCell.Split(',');
string XAxis = string.Empty;
string YAxis = string.Empty;
for (int row = ; row <= table.Rows.Count; row++)
{
if (table.Rows[row - ][ChartKeyword].ToString() != "")
{
for (int j = ; j < TJcellarray.Length; j++)
{
XAxis += "Data!" + GetEXcelstr(TJcellarray[j]) + (row + ) + ",";
YAxis += "test!" + TJcellarray[j] + ",";
}
int Xlength = XAxis.Length;
int Ylength = YAxis.Length;
XAxis = XAxis.Substring(, Xlength - );
YAxis = YAxis.Substring(, Ylength - );
chartSerie = chart.Series.Add(XAxis, YAxis);
chartSerie.HeaderAddress = sheet.Cells[row + , ];//设置每条线的名称
XAxis = "";
YAxis = "";
}
}
#endregion
// chartSerie = ChartData(table, cell, sheet, chartSerie, chart, TJcell,"F36");
       chart.YAxis.MinorTickMark = eAxisTickMark.None;
            chart.XAxis.MinorTickMark = eAxisTickMark.None;//修改刻度线        chart.YAxis.MinorTickMark = eAxisTickMark.None;
            chart.XAxis.MinorTickMark = eAxisTickMark.None;//修改刻度线 chart.SetPosition(table.Rows.Count + , , , );//设置图表位置
} /// <summary>
///饼图
/// </summary>
private static void Pie(DataTable table, ExcelWorksheet sheet, string TJCell, string Chartname, string ChartKeyword)
{
////图表系列
ExcelChartSerie chartSerie = null;
//图表
ExcelChart chart = null;
chart = sheet.Drawings.AddChart(Chartname, eChartType.Pie);
chart.Legend.Position = eLegendPosition.Right;
chart.Legend.Add();
chart.SetSize(, );//设置图表大小
chart.ShowHiddenData = true;
#region 规定单元格生成图表
string[] TJcellarray = TJCell.Split(',');
string XAxis = string.Empty;
string YAxis = string.Empty;
for (int row = ; row <= table.Rows.Count; row++)
{
if (table.Rows[row - ][ChartKeyword].ToString() != "")
{
for (int j = ; j < TJcellarray.Length; j++)
{
XAxis += "Data!" + GetEXcelstr(TJcellarray[j]) + (row + ) + ",";
YAxis += "test!" + TJcellarray[j] + ",";
}
int Xlength = XAxis.Length;
int Ylength = YAxis.Length;
XAxis = XAxis.Substring(, Xlength - );
YAxis = YAxis.Substring(, Ylength - );
chartSerie = chart.Series.Add(XAxis, YAxis);
chartSerie.HeaderAddress = sheet.Cells[row + , ];//设置每条线的名称
XAxis = "";
YAxis = "";
}
}
#endregion
// chartSerie = ChartData(table, cell, sheet, chartSerie, chart, TJcell,"F36");         chart.YAxis.MinorTickMark = eAxisTickMark.None;
            chart.XAxis.MinorTickMark = eAxisTickMark.None;//修改刻度线 chart.SetPosition(table.Rows.Count + +, , , );//设置图表位置
}
/// <summary>
/// 单条簇状柱形图
/// </summary>
private static void singleColumnClustered(DataTable table, ExcelWorksheet sheet, string TJCell, string Chartname, string ChartKeyword)
{
////图表系列
ExcelChartSerie chartSerie = null;
//图表
ExcelChart chart = null;
chart = sheet.Drawings.AddChart(Chartname, eChartType.ColumnClustered);
chart.Legend.Position = eLegendPosition.Right;
chart.Legend.Add();
chart.SetSize(, );//设置图表大小
chart.ShowHiddenData = true;
#region 规定单元格生成图表
string[] TJcellarray = TJCell.Split(',');
string XAxis = string.Empty;
string YAxis = string.Empty;
for (int row = ; row <= table.Rows.Count; row++)
{
if (table.Rows[row - ][ChartKeyword].ToString() != "")
{
for (int j = ; j < TJcellarray.Length; j++)
{
XAxis += "Data!" + GetEXcelstr(TJcellarray[j]) + (row + ) + ",";
YAxis += "test!" + TJcellarray[j] + ",";
}
int Xlength = XAxis.Length;
int Ylength = YAxis.Length;
XAxis = XAxis.Substring(, Xlength - );
YAxis = YAxis.Substring(, Ylength - );
chartSerie = chart.Series.Add(XAxis, YAxis);
chartSerie.HeaderAddress = sheet.Cells[row + , ];//设置每条线的名称
XAxis = "";
YAxis = "";
}
}
#endregion
// chartSerie = ChartData(table, cell, sheet, chartSerie, chart, TJcell,"F36");
       chart.YAxis.MinorTickMark = eAxisTickMark.None;
            chart.XAxis.MinorTickMark = eAxisTickMark.None;//修改刻度线 chart.SetPosition(table.Rows.Count + + , , , );//设置图表位置
}
/// <summary>
/// 提取字符串
/// </summary>
/// <param name="p_str"></param>
/// <returns></returns>
public static string GetEXcelstr(string p_str)
{
string strReturn = string.Empty; if (p_str == null || p_str.Trim() == "")
{
strReturn = "";
} foreach (char chrTemp in p_str)
{
if (!Char.IsNumber(chrTemp))
{ strReturn += chrTemp; }
} return strReturn; }
}
//RangeData类

 public class RangeData
{
///// <param name="XStartCell">数据开始单元格</param>
//public string XStartCell { get; set; }
// /// <param name="XEndCell">数据结束单元格</param>
//public string XEndCell { get; set; }
// /// <param name="EduName">Y开始单元格</param>
//public string YStartCell { get; set; }
// /// <param name="EduName">Y结束单元格</param>
//public string YEndCell { get; set; }
//图表类型 1.ColumnStacked 堆积柱形图 2.ColumnClustered 多条簇状柱形图 3.Pie饼图4.singleColumnClustered 单条簇状图
public string Charttype { get; set; }
//指定Y轴分类标签
public string Yaxis { get; set; }
//用户名
public string UserName { get; set; }
//所在区域
public string Region { get; set; }
//指定时间
public string Appointedtime { get; set; }
//图表名称
public string ChartName { get; set; }
//制图关键字
public string ChartKeyword { get; set; } }

如果执行报错 可能是获取Excel文件地址的问题。

下载地址https://files.cnblogs.com/files/Cjb8973/EpplusExcelChartWeb.rar

使用Epplus生成Excel 图表的更多相关文章

  1. 是用Epplus生成Excel 图表

    1.  前言 这是我最近项目刚要的需求,然后在网上找了半天的教材  但是很不幸,有关于Epplus的介绍真的太少了,然后经过了我的不断研究然后不断的采坑,知道现在看到Excel都想吐的时候,终于成功的 ...

  2. 在.NET中使用EPPlus生成Excel报表 .

    --摘抄自:http://blog.csdn.net/zhoufoxcn/article/details/14112473 在开发.NET应用中可能会遇到需要生成带图表(Chart)的Excel报表的 ...

  3. JAVA生成EXCEL图表

    跟据客户的要求,需要开发一套包括图形的报表,还需要导出WORD 图表需要这样: 这样: 这样: 还有这样: 接下来是实现思路: 以往用的最多的就是JFreechart,手上也有实现各种图形的资源,但是 ...

  4. 使用poi和jfreechart生成excel图表图片

    最近项目在频繁的操作excel,里边涉及到很多和图表有关的东西.有时候需要使用java操作excel自带的图标,比较复杂的我们都是使用excel模板的形式实现. 除此之外,也有一些功能只需要生成对应的 ...

  5. python生成Excel图表(通过xlsxwriter)

    前面介绍了pandas的简单用法,pandas的数据可以通过matlab第三方包将数据生成报表,但是我想将报表生成在Excel中,这时候就可以借助xlsxwriter第三方包来生成图标   缺点:xl ...

  6. EPPlus生成Excel表格(只支持2007及以上)

    主要来源: https://www.cnblogs.com/rumeng/p/3785748.html http://epplus.codeplex.com/ FileInfo newFile = n ...

  7. 【JAVA】POI生成EXCEL图表(柱状图、折线等)

    1.使用excel工具自带的图形工具创建一个图: 2.绑定数据区域: 3.数据区域绑定完成,我们要做的就是将数据写入到数据区域中: 4.标记 5.POI 引入包 <!-- https://mvn ...

  8. EpPlus读取生成Excel帮助类+读取csv帮助类+Aspose.Cells生成Excel帮助类

    大部分功能逻辑都在,少量自定义异常类和扩展方法 ,可用类似代码自己替换 //EpPlus读取生成Excel帮助类+读取csv帮助类,epplus只支持开放的Excel文件格式:xlsx,不支持 xls ...

  9. 生成 excel 插件 Epplus

    最近做 .net core 项目 发现一个新的 生成excel 的插件 . 以前值用 aspose 或者 npio. 简介:Epplus是一个使用Open Office XML(Xlsx)文件格式,能 ...

随机推荐

  1. linux安装git方法

    用git --version命令检查是否已经安装 在CentOS5的版本,由于yum源中没有git,所以需要预先安装一系列的依赖包.在CentOS6的yum源中已经有git的版本了,可以直接使用yum ...

  2. 转载博文: Py西游攻关之IO model

    Py西游攻关之IO model 转载:https://www.cnblogs.com/yuanchenqi/articles/5722574.html 事件驱动模型 上节的问题: 协程:遇到IO操作就 ...

  3. Beta(0/7)

    组长重选议题 Beta阶段计划改进完善的功能 Beta阶段计划新增的功能 需要改进的团队分工 需要改进的工具流程 Beta冲刺的时间计划安排 组长重选议题 没人想当,所以没有换. Beta阶段计划改进 ...

  4. 阿里云服务器端配置TensorFlow & jupyter

    在阿里云上搭建爬取某信的公众号文章的程序时,发现需要验证码验证,技穷之后考虑做一个验证码识别程序,所以开始在服务器上搭建机器学习平台,背景,服务器上已经有其他应用在跑着了,所以不想停服,初始环境:ce ...

  5. 2017-10-22—LD激光二极管原理

    直接摘抄百科了: 在讲激光产生机理之前,先讲一下受激辐射.在光辐射中存在三种辐射过程, 一是处于高能态的粒子自发向低能态跃迁,称之为自发辐射; 二是处于高能态的粒子在外来光的激发下向低能态跃迁,称之为 ...

  6. Python线性表——单链表

    1. 线性表简介 线性表是一种线性结构,它是由零个或多个数据元素构成的有限序列.线性表的特征是在一个序列中,除了头尾元素,每个元素都有且只有一个直接前驱,有且只有一个直接后继,而序列头元素没有直接前驱 ...

  7. [POJ1723]SOLDIERS(中位数)

    题意 给出n个点的坐标,它们只能往上.下.左.右一格一格地移动,求使其移动至水平线上的最小步数. 思路 转载 先易后难,对于纵向的问题,我们推个公式,,这个很容易看出是货仓选址问题,k取y[i]的中位 ...

  8. vue 安装及使用

    一,  vue.js 2.0 1, cnpm install vue-cli -g 全局安装 2, 运行vue查看安装是否成功(创建vue-cli目录: vue init webpack demo) ...

  9. 搭建自己的Webpack项目

    五,搭建自己的Webpack项目  https://www.jianshu.com/p/42e11515c10f

  10. [LeetCode] Insert into a Binary Search Tree 二叉搜索树中插入结点

    Given the root node of a binary search tree (BST) and a value to be inserted into the tree, insert t ...