关闭。这个问题需要细节或清晰。它目前不接受答案。
**想改进这个问题吗?**通过编辑这个帖子来添加细节并澄清问题。
5年前关门了。
改进这个问题
线程“main”org.apache.poi.poifs.filesystem.officexmlfileexception中出现异常:提供的数据似乎在Office2007+xml中。poi只支持org.apache.poi.poifs.storage.headerblockreader上的ole2 office文档。java:96)在org.apache.poi.poifs.filesystem.poifsfilesystem.(poifsfilesystem。java:84)在com.tabletest.main(tabletest。java:19)
import org.apache.poi.hwpf.HWPFDocument;
import org.apache.poi.hwpf.usermodel.Paragraph;
import org.apache.poi.hwpf.usermodel.Range;
import org.apache.poi.hwpf.usermodel.Table;
import org.apache.poi.hwpf.usermodel.TableCell;
import org.apache.poi.hwpf.usermodel.TableRow;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
public class TableTest {
public static void main(String args[]) throws IOException
{
// String fileName="D:\\New folder\\Annual.doc";
InputStream fis=new FileInputStream("D://New folder//Annual.docx");
POIFSFileSystem fs=new POIFSFileSystem(fis);
HWPFDocument doc=new HWPFDocument(fs);
Range range=doc.getRange();
for(int i=0;i<range.numParagraphs();i++)
{
Paragraph par=range.getParagraph(i);
System.out.println(par.text());
}
Paragraph tablePar=range.getParagraph(0);
if(tablePar.isInTable())
{
Table table=range.getTable(tablePar);
for(int rowIdx=0;rowIdx<table.numRows();rowIdx++)
{
TableRow row=table.getRow(rowIdx);
System.out.println("row "+(rowIdx+1)+",is table header: "+row.isTableHeader());
for(int colIdx=0;colIdx<row.numCells();colIdx++)
{
TableCell cell=row.getCell(colIdx);
System.out.println("column "+(colIdx+1)+",text= "+cell.getParagraph(0).text());
}
}
}
}
}
1条答案
按热度按时间iswrvxsc1#
hwpf用于基于ole2的.doc文件。对于.docx文件,您需要改用xwpf。
尝试
XWPFDocument
```XWPFDocument doc=new XWPFDocument(fs);