java表格制作_Java图表绘制和操作excel表格(转)

这篇博客介绍了如何在Java中使用JFreeChart和POI库来绘制图表并操作Excel表格。作者分享了创建柱状图的代码示例,包括设置图表信息、颜色和生成图表URL的函数。博客还提到了数据集的获取和保存图表为PNG格式的方法。
摘要由CSDN通过智能技术生成

http://www.javaeye.com/topic/507427

今天学习了Java中使用JFreeChart,POI,JXL绘制图表,操作excel表格问题,自己动手了写了些小demo,不足之处,请大家指正。谢谢。 ^_^

完整的类文件在附件中。并附上一张截图

====================================

代码『片段』

====================================

Java代码

/**

* 根据数据设置图表的相关信息

* @param categoryDataset

* @return

*/

publicstaticJFreeChart createJFreeChart(CategoryDataset categoryDataset) {

/**

* 设置图表的相关信息,其参数依次为:

* 图表标题,纵坐标显示提示,横坐标显示提示,要显示的数据

* 设置要显示图标柱状的横向或纵向.HORIZONTAL表示纵向,VERTICAL表示横向

* 后面三个boolean型的参数:

* 第一个表示是否显示柱状图例,true为显示,false为不显示

*/

JFreeChart chart = ChartFactory.createBarChart("学生人数统计","省份","数量",

categoryDataset, PlotOrientation.VERTICAL, true,true,false);

// 设置背景颜色

chart.setBackgroundPaint(Color.WHITE);

CategoryPlot cateforyPlot = chart.getCategoryPlot();

cateforyPlot.setBackgroundPaint(Color.WHITE);

cateforyPlot.setDomainGridlinePaint(Color.WHITE);

// 设置是否可见

cateforyPlot.setDomainGridlinesVisible(true);

// 设置柱状的颜色

cateforyPlot.setRangeGridlinePaint(Color.BLUE);

returnchart;

}

/**

* 生成二维的柱状图

* @param session 客户端当前session

* @param out 输出流

* @return 返回所生成图片的URL

*/

publicstaticString getBarChartURL(HttpSession session, PrintWriter out) {

String fileName = "";

//调用静态的方法获取数据集

CategoryDataset categoryDataset = getDataSet();

//调用类中静态方法创建图表对象

JFreeChart chart = createJFreeChart(categoryDataset);

ChartRenderingInfo chartInfo = newChartRenderingInfo(

newStandardEntityCollection());

try{

//将生成的图片以PNG文件格式显示

fileName = ServletUtilities.saveChartAsPNG(chart, 500,300,

chartInfo, session);

} catch(IOException e) {

e.printStackTrace();

}

try{

//向客户端显示图片

ChartUtilities.writeImageMap(out, fileName, chartInfo, true);

} catch(IOException e) {

e.printStackTrace();

}

out.flush();

returnfileName;

}

/** * 根据数据设置图表的相关信息 * @param categoryDataset * @return */public static JFreeChart createJFreeChart(CategoryDataset categoryDataset) {/** * 设置图表的相关信息,其参数依次为: * 图表标题,纵坐标显示提示,横坐标显示提示,要显示的数据 * 设置要显示图标柱状的横向或纵向.HORIZONTAL表示纵向,VERTICAL表示横向 * 后面三个boolean型的参数: * 第一个表示是否显示柱状图例,true为显示,false为不显示 */JFreeChart chart = ChartFactory.createBarChart("学生人数统计", "省份", "数量",categoryDataset, PlotOrientation.VERTICAL, true, true, false);// 设置背景颜色chart.setBackgroundPaint(Color.WHITE);CategoryPlot cateforyPlot = chart.getCategoryPlot();cateforyPlot.setBackgroundPaint(Color.WHITE);cateforyPlot.setDomainGridlinePaint(Color.WHITE);// 设置是否可见cateforyPlot.setDomainGridlinesVisible(true);// 设置柱状的颜色cateforyPlot.setRangeGridlinePaint(Color.BLUE);return chart;}/** * 生成二维的柱状图 * @param session 客户端当前session * @param out 输出流 * @return 返回所生成图片的URL */public static String getBarChartURL(HttpSession session, PrintWriter out) {String fileName = "";//调用静态的方法获取数据集CategoryDataset categoryDataset = getDataSet();//调用类中静态方法创建图表对象JFreeChart chart = createJFreeChart(categoryDataset);ChartRenderingInfo chartInfo = new ChartRenderingInfo(new StandardEntityCollection());try {//将生成的图片以PNG文件格式显示fileName = ServletUtilities.saveChartAsPNG(chart, 500, 300,chartInfo, session);} catch (IOException e) {e.printStackTrace();}try {//向客户端显示图片ChartUtilities.writeImageMap(out, fileName, chartInfo, true);} catch (IOException e) {e.printStackTrace();}out.flush();return fileName;}

66aa233e-2007-356f-8b58-b640392e3b5d.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值