激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務(wù)器之家 - 編程語(yǔ)言 - JAVA教程 - java使用poi讀取ppt文件和poi讀取excel、word示例

java使用poi讀取ppt文件和poi讀取excel、word示例

2019-11-14 15:48java教程網(wǎng) JAVA教程

這篇文章主要介紹了java使用poi讀取ppt文件和poi讀取excel、word示例,需要的朋友可以參考下

Apache的POI項(xiàng)目可以用來(lái)處理MS Office文檔,codeplex上還有一個(gè)它的.net版本。POI項(xiàng)目可創(chuàng)建和維護(hù)操作各種基于OOXML和OLE2文件格式的Java API。大多數(shù)MS Office都是OLE2格式的。POI通HSMF子項(xiàng)目來(lái)支持Outlook,通過HDGF子項(xiàng)目來(lái)支持Visio,通過HPBF子項(xiàng)目來(lái)支持Publisher。

使用POI抽取Word簡(jiǎn)單示例:

要引入poi-3.7.jat和poi-scratchpad-3.7.ajr這兩個(gè)包。

 

復(fù)制代碼代碼如下:


package msoffice;

 

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;

import org.apache.poi.hwpf.HWPFDocument;
import org.apache.poi.hwpf.extractor.WordExtractor;
import org.apache.poi.hwpf.usermodel.CharacterRun;
import org.apache.poi.hwpf.usermodel.Paragraph;
import org.apache.poi.hwpf.usermodel.Range;
import org.apache.poi.hwpf.usermodel.Section;

public class Word {

    // 直接抽取全部?jī)?nèi)容
    public static String readDoc1(InputStream is) throws IOException {
        WordExtractor extractor = new WordExtractor(is);
        return extractor.getText();
    }

    //分章節(jié)Section、段落Paragraph、字符串CharacterRun抽取
    public static void readDoc2(InputStream is) throws IOException {
        HWPFDocument doc=new HWPFDocument(is);
        Range r=doc.getRange();
        for(int x=0;x<r.numSections();x++){
            Section s=r.getSection(x);
            for(int y=0;y<s.numParagraphs();y++){
                Paragraph p=s.getParagraph(y);
                for(int z=0;z<p.numCharacterRuns();z++){
                    CharacterRun run=p.getCharacterRun(z);
                    String text=run.text();
                    System.out.print(text);
                }
            }
        }
    }

    public static void main(String[] args) {
        File file = new File("/home/orisun/1.doc");
        try {
            FileInputStream fin = new FileInputStream(file);
            String cont = readDoc1(fin);
            System.out.println(cont);
            fin.close();
            fin = new FileInputStream(file);
            readDoc2(fin);
            fin.close();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

 

POI抽取PPT示例:

復(fù)制代碼代碼如下:


package msoffice;

 

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;

import org.apache.poi.hslf.HSLFSlideShow;
import org.apache.poi.hslf.extractor.PowerPointExtractor;
import org.apache.poi.hslf.model.Slide;
import org.apache.poi.hslf.model.TextRun;
import org.apache.poi.hslf.usermodel.SlideShow;

public class PPT {

    //直接抽取幻燈片的全部?jī)?nèi)容
    public static String readDoc1(InputStream is) throws IOException{
        PowerPointExtractor extractor=new PowerPointExtractor(is);
        return extractor.getText();
    }

    //一張幻燈片一張幻燈片地讀取
    public static void readDoc2(InputStream is) throws IOException{
        SlideShow ss=new SlideShow(new HSLFSlideShow(is));
        Slide[] slides=ss.getSlides();
        for(int i=0;i<slides.length;i++){
            //讀取一張幻燈片的標(biāo)題
            String style="margin: 3px auto 0px; padding: 0px 3px; outline: none; line-height: 25.2px; font-size: 14px; background: rgb(242, 246, 251); width: 640px; clear: both; border-top: 1px solid rgb(0, 153, 204); border-right: 1px solid rgb(0, 153, 204); border-left: 1px solid rgb(0, 153, 204); border-image: initial; border-bottom: none; font-family: tahoma, arial, "Microsoft YaHei";"> 復(fù)制代碼代碼如下:


package msoffice;

 

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.Iterator;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hssf.extractor.ExcelExtractor;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
import org.apache.poi.ss.usermodel.Row;

public class Excel {

    //直接讀取Excel的全部?jī)?nèi)容
    public static String readDoc1(InputStream is)throws IOException{
        HSSFWorkbook wb=new HSSFWorkbook(new POIFSFileSystem(is));
        ExcelExtractor extractor=new ExcelExtractor(wb);
        extractor.setFormulasNotResults(false);
        extractor.setIncludeSheetNames(true);
        return extractor.getText();
    }

    //讀取時(shí)細(xì)化到Sheet、行甚至單元格
    public static double getAvg(InputStream is)throws IOException{
        HSSFWorkbook wb=new HSSFWorkbook(new POIFSFileSystem(is));
        //獲取第一張sheet
        HSSFSheet sheet=wb.getSheetAt(0);
        double molecule=0.0;
        double denominator=0.0;
        //按行遍歷sheet
        Iterator<Row> riter=sheet.rowIterator();
        while(riter.hasNext()){
            HSSFRow row=(HSSFRow)riter.next();
            HSSFCell cell1=row.getCell(4);
            HSSFCell cell2=row.getCell(4);
            if(cell1.getCellType()!=HSSFCell.CELL_TYPE_NUMERIC){
                System.err.println("數(shù)字類型錯(cuò)誤!");
                System.exit(-2);
            }
            if(cell2.getCellType()!=HSSFCell.CELL_TYPE_NUMERIC){
                System.err.println("數(shù)字類型錯(cuò)誤!");
                System.exit(-2);
            }
            denominator+=Double.parseDouble(cell2.toString().trim());
            molecule+=Double.parseDouble(cell2.toString().trim())*Float.parseFloat(cell1.toString().trim());
        }
        return molecule/denominator;
    }

    public static void main(String[] args){
        File file = new File("/home/orisun/3.xls");
        try{
            FileInputStream fin=new FileInputStream(file);
            String cont=readDoc1(fin);
            System.out.println(cont);
            fin.close();
            fin=new FileInputStream(file);
            System.out.println("加權(quán)平均分"+getAvg(fin));
            fin.close();
        }catch(IOException e){
            e.printStackTrace();
        }
    }
}

 

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 中文字幕在线免费观看电影 | 色奇米| 免费久久久久久 | 久久久一区二区三区四区 | 日日草夜夜草 | 亚洲国产色婷婷 | 精品午夜影院 | 亚洲福利视频52 | 中文字幕在线观看免费视频 | 久久激情国产 | 欧美性生活免费视频 | www.91pron| 视频www| 成人乱人乱一区二区三区 | 黄网站免费观看视频 | 久久久久国产成人免费精品免费 | 午夜影视一区二区 | 2018亚洲男人天堂 | 成人在线视频网 | 舌头伸进添的我好爽高潮网站 | 久久久国产精品成人免费 | 中文字幕网在线 | 精品久久久久久久久久中文字幕 | 性少妇videosexfreexx | 91久久久久久久一区二区 | 把娇妻调教成暴露狂 | 久久成年网站 | 欧美日韩观看 | 一级免费a | 亚洲网站在线 | 免费在线国产 | 久久亚洲春色中文字幕久久 | 羞羞网站 | 91av在线影院 | 欧美一级淫片免费视频黄 | 亚洲成人高清在线观看 | 亚洲午夜免费电影 | 成人福利电影在线观看 | 日日噜噜噜夜夜狠狠久久蜜桃 | 超污视频在线看 | 午夜视频在线观看免费视频 |