使用POI的HWPF操作word(未解决中文乱码问题)
2009-11-17 16:06
981 查看
public class TestPoi extends HttpServlet
{
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException
{
File file = new File("D:\\b.doc");
try
{
FileInputStream in = new FileInputStream("D:\\b.doc");
// HWPFFileSystem hwpfsys = new HWPFFileSystem();
// hwpfsys.getStream("d://b.doc");
POIFSFileSystem pfs = new POIFSFileSystem(in);
HWPFDocument hwpf = new HWPFDocument(pfs);
// hwpf.write(hwpfsys.getStream("D://e.doc"));
// Range range = new Range(0, (int) file.length(), hwpf);
Range range = hwpf.getRange();
StyleSheet styleSheet = hwpf.getStyleSheet();
TableIterator it = new TableIterator(range);
//遍历一个DOC中的所有表格
while (it.hasNext())
{
Table tb = (Table) it.next();
//遍历表格的行
for (int i = 0; i < tb.numRows(); i++)
{
TableRow tr = tb.getRow(i);
//遍历表格的列
for (int j = 0; j < tr.numCells(); j++)
{
//往表格中插入数据
TableCell td = tr.getCell(j);
String text = "第" + i + "行第" + j + "列";
int p = td.numParagraphs();
Paragraph para = td.getParagraph(p);
ParagraphProperties pp = new ParagraphProperties();
para.insertBefore(text);
}
}
}
//在表格外面插入内容
CharacterProperties cp = new CharacterProperties();
cp.setBold(true);
cp.setCharacterSpacing(10);
cp.setChse(cp.SPRM_CHARSCALE);
cp.setCapitalized(true);
int p = range.numParagraphs();
Paragraph para = range.getParagraph(p - 1);
para.insertAfter("test poi successful!", cp);
para.insertAfter("测试成功", cp);
response.setContentType("application/vnd.ms-word");
response.setHeader("Content-disposition", "attachment;filename=e.doc");
OutputStream out = response.getOutputStream();
hwpf.write(out);
out.close();
}
catch (Exception ex)
{
ex.printStackTrace();
}
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException
{
doGet(request, response);
}
}
{
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException
{
File file = new File("D:\\b.doc");
try
{
FileInputStream in = new FileInputStream("D:\\b.doc");
// HWPFFileSystem hwpfsys = new HWPFFileSystem();
// hwpfsys.getStream("d://b.doc");
POIFSFileSystem pfs = new POIFSFileSystem(in);
HWPFDocument hwpf = new HWPFDocument(pfs);
// hwpf.write(hwpfsys.getStream("D://e.doc"));
// Range range = new Range(0, (int) file.length(), hwpf);
Range range = hwpf.getRange();
StyleSheet styleSheet = hwpf.getStyleSheet();
TableIterator it = new TableIterator(range);
//遍历一个DOC中的所有表格
while (it.hasNext())
{
Table tb = (Table) it.next();
//遍历表格的行
for (int i = 0; i < tb.numRows(); i++)
{
TableRow tr = tb.getRow(i);
//遍历表格的列
for (int j = 0; j < tr.numCells(); j++)
{
//往表格中插入数据
TableCell td = tr.getCell(j);
String text = "第" + i + "行第" + j + "列";
int p = td.numParagraphs();
Paragraph para = td.getParagraph(p);
ParagraphProperties pp = new ParagraphProperties();
para.insertBefore(text);
}
}
}
//在表格外面插入内容
CharacterProperties cp = new CharacterProperties();
cp.setBold(true);
cp.setCharacterSpacing(10);
cp.setChse(cp.SPRM_CHARSCALE);
cp.setCapitalized(true);
int p = range.numParagraphs();
Paragraph para = range.getParagraph(p - 1);
para.insertAfter("test poi successful!", cp);
para.insertAfter("测试成功", cp);
response.setContentType("application/vnd.ms-word");
response.setHeader("Content-disposition", "attachment;filename=e.doc");
OutputStream out = response.getOutputStream();
hwpf.write(out);
out.close();
}
catch (Exception ex)
{
ex.printStackTrace();
}
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException
{
doGet(request, response);
}
}
相关文章推荐
- 树莓派 Learning 002 装机后的必要操作 11 解决在使用SecureCRT软件链接树莓派时,SecureCRT软件的终端中显示树莓派的中文字体乱码的问题
- Jena API使用详解(关注将本体持久化到MySQL后的操作及解决中文乱码等问题)
- 解决使用secureCRT操作数据库时出现中文乱码问题
- 使用xshell登录中文版CentOS时,在xshell下显示中文乱码,通过如下办法可以有效的解决乱码问题
- Python使用SQLAlchemy,并且解决了插入中文乱码问题
- 使用servlet编程,解决输出到页面的中文显示乱码问题。
- phpmyadmin使用load语句导入.dat数据中文乱码问题解决
- 解决spring3.0.5使用RestTemplate发送post请求响应中文乱码问题
- 关于android 使用Scoket通信中文乱码问题的解决
- PHP使用mb_substr()解决中文字符串截取乱码问题
- 使用windows Builder的一个中文乱码问题解决
- 在win7下使用zend studio 7.1.0,解决汉化、中文乱码、js等问题
- 使用Xcode4.4打开Winnows下C文件中文乱码问题解决
- 解决openfire在使用MySQL数据库后的中文乱码问题
- 使用c3p0连接池操作mysql数据库中文乱码解决办法
- Oracle客户端使用sqlldr导数据中文乱码问题解决方法
- 使用apache ant jar包 进行zip 打包操作 (解决中文问题)
- DOS命令行操作MySQL数据库中文乱码问题解决
- 解决delphi使用sqlite时中文最后一个字是乱码的问题
- 使用gSOAP开发实例(3) iconv解决中文乱码问题