亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? testcrossreport.java

?? 這是一個報表開發包,支持中國樣式的報表,支持分組和交叉報表
?? JAVA
字號:
package test;

import java.io.*;
import java.util.*;
import javax.xml.parsers.*;

import java.awt.*;

import org.apache.poi.hssf.usermodel.*;
import org.apache.poi.hssf.util.*;
import org.w3c.dom.*;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import com.lowagie.text.Font;
import com.lowagie.text.pdf.*;
import com.lucaslee.report.*;
import com.lucaslee.report.grouparithmetic.*;
import com.lucaslee.report.model.*;
import com.lucaslee.report.model.Table;
import com.lucaslee.report.model.crosstable.*;
import com.lucaslee.report.printer.*;

/**
 * 生成交叉表報表例子。
 * 從main方法開始執行。
 * 注意:例子中對程序段的注釋,方法是:在程序段前面加注釋,在程序段后面注明段的結束.如:
 * 前面://****xxxx***********
  * 后面://****end xxxx*******
   *
   * <p>Copyright: Copyright (c) 2004</p>
   * <p>Company:Lucas-lee Soft </p>
   * @author Lucas Lee
   * @version 1.0
   */
  public class TestCrossReport {
    public TestCrossReport() {
    }

    /**
     * 根據報表對象生成csv格式的報表.
     * @param report 報表對象
     * @throws Exception
     */
    public static void getExcelReport(Report report) throws Exception {
      //設置輸出的文件
      FileOutputStream fo = new FileOutputStream("crossTab.xls");

      ExcelCss css = new ExcelCss() {
        public void init(HSSFWorkbook workbook) {

          //*****************定義字體*****************
           //普通字體
           HSSFFont fontNormal = workbook.createFont();
          fontNormal.setFontHeightInPoints( (short) 10);
          fontNormal.setFontName("宋體");

          //粗體
          HSSFFont fontBold = workbook.createFont();
          fontBold.setFontHeightInPoints( (short) 10);
          fontBold.setFontName("宋體");
          fontBold.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);

          //大、粗字體
          HSSFFont fontBig = workbook.createFont();
          fontBig.setFontHeightInPoints( (short) 15);
          fontBig.setFontName("宋體");
          fontBig.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
          //*****************end定義字體*****************

           //***************設置EXCEL報表的樣式表******************
          HSSFCellStyle style = workbook.createCellStyle();
          style.setFillForegroundColor(HSSFColor.PALE_BLUE.index);
          style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
          style.setFont(fontNormal);
          this.setGroupTotal(style);

          style = workbook.createCellStyle();
          style.setFillForegroundColor(HSSFColor.PALE_BLUE.index);
          style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
          style.setFont(fontNormal);
          this.setGroupTotal(style);

          this.setTotal(style);

          style = workbook.createCellStyle();
          style.setFillForegroundColor(HSSFColor.LIGHT_ORANGE.index);
          style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
          style.setFont(fontBold);
          this.setHead(style);

          style = workbook.createCellStyle();
          style.setFont(fontBig);
          this.setTitle(style);

          style = workbook.createCellStyle();
          style.setFont(fontNormal);
          this.setData(style);

          style = workbook.createCellStyle();
          style.setFillForegroundColor(HSSFColor.ORANGE.index);
          style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
          style.setFont(fontNormal);
          this.setCrossHeadHead(style);

          this.setDefaultColumnWidth( (short) 10);
          //***************end 設置EXCEL報表的樣式表******************
        }
      };

      //執行EXCEL格式報表的輸出
      new ExcelPrinter().print(report, css, fo);

      //關閉輸出文件
      fo.close();
      System.out.println("生成Excel格式報表成功。");
    }

    /**
     * 根據報表對象生成HTML格式的報表.
     * @param report 報表對象
     * @throws Exception
     */
    public static void getHTMLReport(Report report) throws Exception {
      //設置輸出的文件
      FileOutputStream fo = new FileOutputStream("crossTab.html");

      //***************設置HTML報表的樣式表******************
      HTMLCss css = new HTMLCss();
      css.setGroupTotal("BACKGROUND-COLOR: #d8e4f1; font: bold 12pt 隸書;");
      css.setHead("BACKGROUND-COLOR: #ffdead; font: bold 12pt 隸書;");
      css.setTotal("BACKGROUND-COLOR: #d8e4f1; font: bold 12pt 隸書;");
      css.setTitle("font: bold 18pt ;");
      css.setData("font: 12pt");
      css.setCrossHeadHead("BACKGROUND-COLOR: #a68763; font: 9pt ");
      //***************end 設置HTML報表的樣式表******************

       //執行HTML格式報表的輸出
      new HTMLPrinter().print(report, css, fo);

      //關閉輸出文件
      fo.close();
      System.out.println("生成HTML格式報表成功。");
    }

    /**
     * 根據報表對象生成pdf格式的報表.
     * @param report 報表對象
     * @throws Exception
     */
    public static void getPDFReport(Report report) throws Exception {
      //設置輸出的文件
      FileOutputStream fo = new FileOutputStream("crossTab.pdf");

      //******************定義pdf中文字體*****************
      BaseFont bfChinese = BaseFont.createFont("STSong-Light", "UniGB-UCS2-H",
                                               BaseFont.NOT_EMBEDDED);
      BaseFont bfChineseBold = BaseFont.createFont("STSong-Light,Bold",
          "UniGB-UCS2-H",
          BaseFont.NOT_EMBEDDED);
      Font FontChinese = new Font(bfChinese, 10, Font.NORMAL);
      Font FontChineseBold = new Font(bfChineseBold, 10, Font.NORMAL);
      //******************end 定義pdf中文字體*****************

       //****************設置pdf報表的樣式表*********************
      PDFCss css = new PDFCss();

      PDFCssItem item = new PDFCssItem();
      item.setBackgroudColor(new Color(0xd8e4f1));
      item.setFont(FontChinese);
      css.setGroupTotal(item);
      css.setTotal(item);

      item = new PDFCssItem();
      item.setBackgroudColor(new Color(0xffdead));
      item.setFont(FontChineseBold);
      css.setHead(item);

      item = new PDFCssItem();
      item.setFont(new Font(bfChineseBold, 15, Font.BOLD));
      css.setTitle(item);

      item = new PDFCssItem();
      item.setFont(new Font(bfChinese, 10, Font.NORMAL));
      css.setData(item);

      item = new PDFCssItem();
      item.setFont(new Font(bfChinese, 7, Font.NORMAL));
      item.setBackgroudColor(new Color(0xffdead));
      css.setCrossHeadHead(item);
      //****************end 設置pdf報表的樣式表*********************

       //執行PDF格式報表的輸出
      new PDFPrinter().print(report, css, fo);

      //關閉輸出文件
      fo.close();
      System.out.println("生成PDF格式報表成功。");
    }

    /**
     * 根據報表對象生成csv格式的報表.
     * @param report 報表對象
     * @throws Exception
     */
    public static void getCSVReport(Report report) throws Exception {
      //設置輸出的文件
      FileOutputStream fo = new FileOutputStream("crossTab.csv");

      //執行CSV格式報表的輸出
      new CSVPrinter().print(report, fo);

      //關閉輸出文件
      fo.close();
      System.out.println("生成CSV格式報表成功。");
    }

    /**
     * 設置報表的頭部和尾部.
     * @param report 要設置頭尾的報表對象.
     * @throws ReportException
     */
    private static void setTitleFooter(Report report) throws ReportException {
      //*****************設置報表頭部*********************
       Table headerTable = new Table();
       //設置表格的寬度比例(百分比)
      int[] widths = {
          20, 60, 20};
      headerTable.setWidths(widths);
      report.setHeaderTable(headerTable);

      headerTable.setBorder(0);
      headerTable.setAlign(headerTable.ALIGN_CENTER);

      TableCell tc = null;
      TableRow tr = null;

      tr = new TableRow(3);
      headerTable.addRow(tr);
      tc = tr.getCell(0);
      tc.setColSpan(3);
      tc.setAlign(tc.ALIGN_CENTER);
      tc.setContent("中國XXX股份有限公司XXX分公司");
      tr.getCell(1).setIsHidden(true);
      tr.getCell(2).setIsHidden(true);

      tr = new TableRow(3);
      headerTable.addRow(tr);
      tc = tr.getCell(0);
      tc.setColSpan(3);
      tc.setAlign(tc.ALIGN_CENTER);
      tc.setContent("產品銷售統計報表");
      tc.setCssClass(Report.TITLE_TYPE);
      tr.getCell(1).setIsHidden(true);
      tr.getCell(2).setIsHidden(true);

      tr = new TableRow(3);
      headerTable.addRow(tr);

      tr = new TableRow(3);
      headerTable.addRow(tr);
      tc = tr.getCell(0);
      tc.setContent("單位:xxx分公司");
      tc.setAlign(tc.ALIGN_LEFT);
      tc = tr.getCell(1);
      tc.setContent("報表日期:2003-11-11至2003-11-16");
      tc.setAlign(tc.ALIGN_CENTER);
      tc = tr.getCell(2);
      tc.setAlign(tc.ALIGN_RIGHT);
      tc.setContent("單位:噸  元");
      //*****************end 設置報表頭部*********************

       //*****************設置報表尾部*********************
      Table footerTable = new Table();
      report.setFooterTable(footerTable);

      tr = new TableRow(3);
      footerTable.setBorder(0);
      footerTable.setAlign(footerTable.ALIGN_CENTER);
      footerTable.addRow(tr);
      tr.getCell(0).setContent("制表人:xxx");
      tr.getCell(0).setAlign(tc.ALIGN_LEFT);
      tr.getCell(1).setContent("審核人:xxx");
      tr.getCell(1).setAlign(tc.ALIGN_CENTER);
      tr.getCell(2).setContent("制表日期:xxx");
      tr.getCell(2).setAlign(tc.ALIGN_RIGHT);
      //*****************end 設置報表尾部*********************
    }

    /**
     * 從xml文件獲得原始數據表格.注意其中使用的crossTabSample.xml應該設置為此文件所在的路徑.
     * @return
     * @throws Exception
     */
    private static Table getTableByXML() throws Exception {
      //xml文件路徑,應該設置為crossTabSample.xml所在的路徑
      String fileName = "crossTabSample.xml";
      Table t = new Table();

      //用JAXP讀取xml文件
      Document doc = DocumentBuilderFactory.newInstance().newDocumentBuilder().
          parse(new File(fileName));
      Element e = doc.getDocumentElement();
      NodeList xmlTab = e.getChildNodes();
      for (int i = 0; i < xmlTab.getLength(); i++) {
        if (xmlTab.item(i).getNodeName().equals("Row")) {
          TableRow tr = new TableRow();
          NodeList xmlTR = xmlTab.item(i).getChildNodes();
          for (int j = 0; j < xmlTR.getLength(); j++) {
            if (xmlTR.item(j).getNodeName().equals("data")) {
              TableCell tc = new TableCell();
              tc.setContent(xmlTR.item(j).getFirstChild().getNodeValue());
              tr.addCell(tc);
            }
          }
          t.addRow(tr);
        }
      }
      return t;
    }

    public static void main(String[] args) throws Exception {
      //報表管理器
      ReportManager rm = new ReportManager();

      //待處理的原始數據表格對象
      Table t = getTableByXML();

      //************定義交叉表*************
      HeadCol[] colH = {
          new HeadCol(2, "廠家")};
      HeadCol[] rowH = {
          new HeadCol(0, "品種"), new HeadCol(1, "市場")};
      Vector sort1 = new Vector();
      sort1.add("本單位");
      sort1.add("長江牌");
      colH[0].setSortSeq(sort1);

      CrossCol crs = new CrossCol(3, "銷售額", new SumArithmetic());
      CrossTable crossTab = new CrossTable(colH, rowH, crs);
      //************end 定義交叉表*************

       //通過原始數據和交叉表的定義生成交叉表
      t = rm.generateCrossTab(t, crossTab);

      //進行行統計
      t = rm.generateCrossTabRowTotal(t, crossTab, true,
                                      new SumArithmetic());

      //進行列統計
      t = rm.generateCrossTabColTotal(t, crossTab, false, new SumArithmetic());

      //格式化數據
      t = rm.formatData(t, crossTab, new DefaultFormatter());

      //****************定義報表的其他部分****************
      Report report = new Report();

      //將交叉表設為報表的主體
      ReportBody body = new ReportBody();
      body.setData(t);
      report.setBody(body);

      //設置報表的頭和尾兩部分
      setTitleFooter(report);
      //****************end 定義報表的其他部分************

       //生成HTML格式報表
      getHTMLReport(report);
      //生成PDF格式報表
      getPDFReport(report);
      //生成CSV格式報表
      getCSVReport(report);
      //生成Excel格式報表
      getExcelReport(report);
    }

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
三级影片在线观看欧美日韩一区二区| 欧美不卡视频一区| 不卡的av在线播放| 日本韩国一区二区三区视频| 欧美日韩中文精品| 久久香蕉国产线看观看99| 国产精品欧美久久久久一区二区| 中文字幕视频一区| 日本欧美在线看| 91小宝寻花一区二区三区| 日韩欧美国产高清| 中文字幕一区日韩精品欧美| 欧美a一区二区| 91国在线观看| 亚洲激情自拍视频| 国产老妇另类xxxxx| 日本道免费精品一区二区三区| 2020国产精品自拍| 日韩国产欧美三级| 717成人午夜免费福利电影| 亚洲欧美日韩国产综合| 成人亚洲一区二区一| 国产精品美女久久久久av爽李琼 | 亚洲精品一区二区三区99| 亚洲线精品一区二区三区| 成人性视频网站| 国产精品美女久久久久久久| 国产一区二区按摩在线观看| 久久美女艺术照精彩视频福利播放| 亚洲成人资源网| 欧美日韩不卡在线| 欧美bbbbb| 日本一区二区视频在线| 成人免费电影视频| 亚洲欧美另类小说| 欧美日韩中文字幕一区| 日产欧产美韩系列久久99| 91精品国产入口在线| 久99久精品视频免费观看| 国产丝袜欧美中文另类| 日本丰满少妇一区二区三区| 欧美bbbbb| 国产精品激情偷乱一区二区∴| 99精品久久只有精品| 亚洲成人综合视频| 国产午夜精品福利| 欧美久久久久久蜜桃| 波多野结衣亚洲| 免费美女久久99| 亚洲激情图片小说视频| 久久综合色播五月| 色婷婷精品久久二区二区蜜臀av| 日韩精品一二三| 亚洲欧美日韩国产手机在线| 久久久五月婷婷| 日韩一区二区在线播放| 在线观看国产日韩| www.激情成人| 一本一道久久a久久精品综合蜜臀 一本一道综合狠狠老 | 亚洲欧美另类小说视频| 精品日韩成人av| 精品国产凹凸成av人导航| 91在线视频官网| 色哟哟国产精品| 色系网站成人免费| 91精彩视频在线| 欧美性猛交xxxxxx富婆| 欧美视频一区在线| 欧美美女bb生活片| 日韩一区二区三区av| 日韩情涩欧美日韩视频| 国产亚洲精品中文字幕| 国产精品色婷婷| 夜夜精品视频一区二区| 五月天激情综合网| 九一九一国产精品| 色综合天天天天做夜夜夜夜做| 欧美三级一区二区| 亚洲精品一线二线三线| 国产精品国产自产拍高清av| 午夜精品123| 国产揄拍国内精品对白| 91麻豆免费观看| xvideos.蜜桃一区二区| 一区二区激情视频| 成人免费观看av| 精品久久免费看| 亚洲一区二区三区免费视频| 国内成+人亚洲+欧美+综合在线| 欧美中文字幕不卡| 久久人人97超碰com| 日本不卡免费在线视频| 91电影在线观看| ●精品国产综合乱码久久久久| 蜜臀精品一区二区三区在线观看| 99久久99久久久精品齐齐| 欧美不卡一区二区三区四区| 亚洲香肠在线观看| 色天使久久综合网天天| 一区二区三区在线影院| 成人性视频免费网站| 久久精品一区二区三区不卡 | 国产日韩欧美不卡在线| 久久精品国产色蜜蜜麻豆| 欧美视频一区在线观看| 亚洲一区二区黄色| 欧美日韩专区在线| 日日摸夜夜添夜夜添国产精品| 9人人澡人人爽人人精品| 中文字幕第一区第二区| 国产成人在线网站| 成人欧美一区二区三区小说| 99这里只有久久精品视频| 亚洲人被黑人高潮完整版| 色天天综合色天天久久| 精品一区二区三区影院在线午夜| 精品国产成人系列| 99久久久久免费精品国产 | 亚洲免费观看在线观看| 欧美另类高清zo欧美| 看片的网站亚洲| 成人免费在线播放视频| 日韩色在线观看| 成人av网址在线| 婷婷久久综合九色综合绿巨人| 欧美国产欧美综合| 欧美色综合影院| 成人国产电影网| 美女在线观看视频一区二区| 亚洲精品视频在线观看网站| 精品电影一区二区三区| 欧美日本在线看| 99久久精品一区| 国产成人精品免费视频网站| 日韩国产欧美在线播放| 一区二区三区欧美久久| 亚洲蜜臀av乱码久久精品蜜桃| 精品国产一区二区三区久久影院| 欧美午夜电影一区| 99久久综合色| 国产激情偷乱视频一区二区三区| 天堂一区二区在线免费观看| 亚洲电影一级黄| 亚洲一区二区三区影院| 亚洲欧洲精品一区二区精品久久久| 国产婷婷色一区二区三区在线| 国产欧美日韩综合| 国产亚洲精品精华液| 国产亚洲综合在线| 久久蜜桃av一区精品变态类天堂 | 欧美午夜电影在线播放| 欧美男男青年gay1069videost| 一本色道久久综合精品竹菊| 欧美艳星brazzers| 欧美一区二区三区四区五区 | 69堂亚洲精品首页| 精品国产一区二区三区av性色| wwww国产精品欧美| 亚洲欧洲另类国产综合| 亚洲一区在线观看免费观看电影高清 | jvid福利写真一区二区三区| 欧美日韩一区中文字幕| 亚洲精品在线观看网站| 亚洲私人影院在线观看| 日本亚洲免费观看| av中文字幕亚洲| 日韩精品在线网站| 亚洲综合精品久久| 国产精品系列在线观看| 日韩一区二区三区高清免费看看| 亚洲欧美日韩电影| 国产精品123| 久久欧美一区二区| 日韩精品视频网站| 欧美色精品在线视频| 国产精品国产精品国产专区不片| 蜜桃视频一区二区三区在线观看| 一本久道中文字幕精品亚洲嫩| 中文字幕一区二区三区四区不卡 | 欧美日韩黄色影视| 亚洲国产精品一区二区久久 | 91精品国产综合久久久久| 欧美巨大另类极品videosbest | 久久不见久久见免费视频1| 国产精品日韩精品欧美在线| 91精品婷婷国产综合久久性色 | 久久成人免费网| 精品久久久久香蕉网| 91在线云播放| 亚洲成av人综合在线观看| 日韩美女一区二区三区四区| 紧缚奴在线一区二区三区| 国产精品国产三级国产aⅴ入口| 欧美性猛交xxxx黑人交| 国产剧情一区二区| 亚洲男人的天堂一区二区| 日韩一本二本av| 色婷婷久久99综合精品jk白丝| 久久精品国产第一区二区三区| 亚洲欧美激情一区二区|