关于poi写java的信息

博主:adminadmin 2023-01-01 03:06:07 655

今天给各位分享poi写java的知识,其中也会对进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!

本文目录一览:

怎么使用JAVA,POI读写word文档

如何使用JAVA、POI读写word文档??

能不能将一个word的内容完全读过来,放到一个新生成的word文件中去,要求能将word中的表格、图片等保留,格式不变。最好能给个例子?网上多是很早以前的那个解决方法如下:,只能读文本内容,且新生成的word文件打开时总是要提示选择编码,不太好用,希望能有新的解决方案??!!

poi操作word

1.1 添加poi支持:包下载地址

1.2 POI对Excel文件的读取操作比较方便,POI还提供对Word的DOC格式文件的读取。但在它的发行版本中没有发布对Word支持的模块,需要另外下载一个POI的扩展的Jar包。下载地址为;下载extractors-0.4_zip这个文件

2、提取Doc文件内容

public static String readDoc(String doc) throws Exception {

// 创建输入流读取DOC文件

FileInputStream in = new FileInputStream(new File(doc));

WordExtractor extractor = null;

String text = null;

// 创建WordExtractor

extractor = new WordExtractor();

// 对DOC文件进行提取

text = extractor.extractText(in);

return text;

}

public static void main(String[] args) {

try{

String text = WordReader.readDoc("c:/test.doc");

System.out.println(text);

}catch(Exception e){

e.printStackTrace();

}

}

3、写入Doc文档

import java.io.ByteArrayInputStream;

import java.io.FileOutputStream;

import java.io.IOException;

import org.apache.poi.poifs.filesystem.DirectoryEntry;

import org.apache.poi.poifs.filesystem.DocumentEntry;

import org.apache.poi.poifs.filesystem.POIFSFileSystem;

public class WordWriter {

public static boolean writeDoc(String path, String content) {

boolean w = false;

try {

// byte b[] = content.getBytes("ISO-8859-1");

byte b[] = content.getBytes();

ByteArrayInputStream bais = new ByteArrayInputStream(b);

POIFSFileSystem fs = new POIFSFileSystem();

DirectoryEntry directory = fs.getRoot();

DocumentEntry de = directory.createDocument("WordDocument", bais);

FileOutputStream ostream = new FileOutputStream(path);

fs.writeFilesystem(ostream);

bais.close();

ostream.close();

} catch (IOException e) {

e.printStackTrace();

}

return w;

}

public static void main(String[] args) throws Exception{

String wr=WordReader.readDoc("D:\\test.doc");

boolean b = writeDoc("D:\\result.doc",wr);

使用POI进行写操作

Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能。

官网可以找到文档和每个版本的下载地址

项目名:excel-poi

注意:如果针对不同版本的Excel使用了不适合的类库,则会报告异常

org.apache.poi.POIXMLException: org.apache.poi.openxml4j.exceptions.InvalidFormatException: Package should contain a content type part [M1.13]

缺点:最多只能处理65536行,否则会抛出异常

java.lang.IllegalArgumentException: Invalid row number (65536) outside allowable range (0..65535)

优点:过程中写入缓存,不操作磁盘,最后一次性写入磁盘,速度快

缺点: 写数据时速度非常慢, 非常耗内存,也会发生内存溢出,如100万条

优点:可以写较大的数据量,如20万条

优点:可以写非常大的数据量,如100万条甚至更多条,写数据速度快,占用更少的内存

注意:

过程中会产生临时文件,需要清理临时文件(C:UsershelenAppDataLocalTemp)

默认由100条记录被保存在内存中,如果查过这数量,则最前面的数据被写入临时文件

如果想自定义内存中数据的数量,可以使用new SXSSFWorkbook(数量)

SXSSFWorkbook-来至官方的解释:实现“BigGridDemo”策略的流式XSSFWorkbook版本。这允许写入非常大的文件而不会耗尽内存,因为任何时候只有可配置的行部分被保存在内存中。

请注意,仍然可能会消耗大量内存,这些内存基于您正在使用的功能,例如合并区域,注释......仍然只存储在内存中,因此如果广泛使用,可能需要大量内存。

如何使用JAVA,POI读写word文档

public class HwpfTest {

@SuppressWarnings("deprecation")

@Test

public void testReadByExtractor() throws Exception {

InputStream is = new FileInputStream("D:\\test.doc");

WordExtractor extractor = new WordExtractor(is);

//输出word文档所有的文本

System.out.println(extractor.getText());

System.out.println(extractor.getTextFromPieces());

//输出页眉的内容

System.out.println("页眉:" + extractor.getHeaderText());

//输出页脚的内容

System.out.println("页脚:" + extractor.getFooterText());

//输出当前word文档的元数据信息,包括作者、文档的修改时间等。

System.out.println(extractor.getMetadataTextExtractor().getText());

//获取各个段落的文本

String paraTexts[] = extractor.getParagraphText();

for (int i=0; iparaTexts.length; i++) {

System.out.println("Paragraph " + (i+1) + " : " + paraTexts[i]);

}

//输出当前word的一些信息

printInfo(extractor.getSummaryInformation());

//输出当前word的一些信息

this.printInfo(extractor.getDocSummaryInformation());

this.closeStream(is);

}

/**

* 输出SummaryInfomation

* @param info

*/

private void printInfo(SummaryInformation info) {

//作者

System.out.println(info.getAuthor());

//字符统计

System.out.println(info.getCharCount());

//页数

System.out.println(info.getPageCount());

//标题

System.out.println(info.getTitle());

//主题

System.out.println(info.getSubject());

}

/**

* 输出DocumentSummaryInfomation

* @param info

*/

private void printInfo(DocumentSummaryInformation info) {

//分类

System.out.println(info.getCategory());

//公司

System.out.println(info.getCompany());

}

/**

* 关闭输入流

* @param is

*/

private void closeStream(InputStream is) {

if (is != null) {

try {

is.close();

} catch (IOException e) {

e.printStackTrace();

}

}

}

}

我想用java poi 写个EXCEL导出工具,用什么设计模式写比较好,原因是什么?

设计模式是解决特定问题的。如果你的导出工具没有或者很少有这样的问题,那完全不必用设计模式的。就按照普通的java程序写就可以。如果你要可重用程度高,只要注重抽象即可。

关于poi写java和的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。