天天看點

Java圖表繪制和操作excel表格(轉)

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

今天學習了Java中使用JFreeChart,POI,JXL繪制圖表,操作excel表格問題,自己動手了寫了些小demo,不足之處,請大家指正。謝謝。 ^_^

完整的類檔案在附件中。并附上一張截圖

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

代碼『片段』

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

Java代碼

  1. /** 
  2.      * 根據資料設定圖表的相關資訊 
  3.      * @param categoryDataset 
  4.      * @return 
  5.      */  
  6.     public static JFreeChart createJFreeChart(CategoryDataset categoryDataset) {  
  7.         /** 
  8.          * 設定圖表的相關資訊,其參數依次為: 
  9.          * 圖表标題,縱坐标顯示提示,橫坐标顯示提示,要顯示的資料 
  10.          * 設定要顯示圖示柱狀的橫向或縱向.HORIZONTAL表示縱向,VERTICAL表示橫向 
  11.          * 後面三個boolean型的參數: 
  12.          * 第一個表示是否顯示柱狀圖例,true為顯示,false為不顯示 
  13.          */  
  14.         JFreeChart chart = ChartFactory.createBarChart("學生人數統計", "省份", "數量",  
  15.                 categoryDataset, PlotOrientation.VERTICAL, true, true, false);  
  16.         // 設定背景顔色  
  17.         chart.setBackgroundPaint(Color.WHITE);  
  18.         CategoryPlot cateforyPlot = chart.getCategoryPlot();  
  19.         cateforyPlot.setBackgroundPaint(Color.WHITE);  
  20.         cateforyPlot.setDomainGridlinePaint(Color.WHITE);  
  21.         // 設定是否可見  
  22.         cateforyPlot.setDomainGridlinesVisible(true);  
  23.         // 設定柱狀的顔色  
  24.         cateforyPlot.setRangeGridlinePaint(Color.BLUE);  
  25.         return chart;  
  26.     }  
  27.     /** 
  28.      * 生成二維的柱狀圖 
  29.      * @param session 用戶端目前session 
  30.      * @param out 輸出流 
  31.      * @return 傳回所生成圖檔的URL 
  32.      */  
  33.     public static String getBarChartURL(HttpSession session, PrintWriter out) {  
  34.         String fileName = "";  
  35.         //調用靜态的方法擷取資料集  
  36.         CategoryDataset categoryDataset = getDataSet();  
  37.         //調用類中靜态方法建立圖表對象  
  38.         JFreeChart chart = createJFreeChart(categoryDataset);  
  39.         ChartRenderingInfo chartInfo = new ChartRenderingInfo(  
  40.                 new StandardEntityCollection());  
  41.         try {  
  42.             //将生成的圖檔以PNG檔案格式顯示  
  43.             fileName = ServletUtilities.saveChartAsPNG(chart, 500, 300,  
  44.                     chartInfo, session);  
  45.         } catch (IOException e) {  
  46.             e.printStackTrace();  
  47.         }  
  48.         try {  
  49.             //向用戶端顯示圖檔  
  50.             ChartUtilities.writeImageMap(out, fileName, chartInfo, true);  
  51.         } catch (IOException e) {  
  52.             e.printStackTrace();  
  53.         }  
  54.         out.flush();  
  55.         return fileName;  
  56.     }  
/** * 根據資料設定圖表的相關資訊 * @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;}      
Java圖表繪制和操作excel表格(轉)