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. Vue基础语法

    一.挂载点,模版和实例 二.Vue实例中的数据,事件和方法 1.v-html指令和v-text指令 v-html :不转义 v-text :转义过后的内容 <div id="root& ...

  2. 在macOS下使用MAXPP搭建本地开发服务器简易流程

    本文适用于解决前端开发时所需的服务器支持,包括文件上传和下载.在开发环境中需要保持尽量的开放,并不是安全的.根据浏览器安全协议,所下载的开源项目是不能直接在file中直接打开的,需要把文件放置在服务器 ...

  3. tensorflow例子-【老鱼学tensorflow】

    本节主要用一个例子来讲述一下基本的tensorflow用法. 在这个例子中,我们首先伪造一些线性数据点,其实这些数据中本身就隐藏了一些规律,但我们假装不知道是什么规律,然后想通过神经网络来揭示这个规律 ...

  4. day17.初识递归函数

    在一个函数调用这个函数本身就是递归函数 递归函数默认深度最大997 n = 0 def func(): global n n += 1 print('hello,world') print(n) fu ...

  5. chattr和lsattr的基本用法

    lsattr filename  查看一个文件的属性 chattr filename  改变一个文件的属性 主要用途:实现文件的原有内容不允许改变,但可以增加新行,则需通过改变文件的属性来实现. ch ...

  6. 洛谷.3733.[HAOI2017]八纵八横(线性基 线段树分治 bitset)

    LOJ 洛谷 最基本的思路同BZOJ2115 Xor,将图中所有环的异或和插入线性基,求一下线性基中数的异或最大值. 用bitset优化一下,暴力的复杂度是\(O(\frac{qmL^2}{w})\) ...

  7. linux打包文件和压缩

    1.解压:tar -zxvf archive.tar , unzip file1.zip 2.压缩:tar -cvfz archive.tar.gz dir1 , zip file1.zip file ...

  8. 马昕璐 201771010118《面向对象程序设计(java)》第六周学习总结

    第一部分:理论知识学习部分 1.继承 继承:用已有类来构建新类的一种机制.当定义了一个新类继承了一个类时,这个新类就继承了这个类的方法和域,同时在新类中添加新的方法和域以适应新的情况. 继承是Java ...

  9. Grunt connect

    使用connect打开指定html方法 由于localhost会直接链接到了index.html,所以我们可以通过base选项设置打开html,这是我的目录,我要打开根目录下的test.html co ...

  10. html中的列表

    无序列表(什么前面默认一个实心的黑原点) <ul> <li>什么</li> <li>什么</li> <li>什么</li& ...