首页 > 开发 > Java > 正文

解析Java的InputStream类并借助其读取ppt文件

2024-07-13 09:56:03
字体:
来源:转载
供稿:网友

这篇文章主要介绍了Java的InputStream类并借助其读取ppt文件,讲到了InputStream类中一些常用的方法的问题,需要的朋友可以参考下

1. 关于InputStream.read()

在从数据流里读取数据时,为图简单,经常用InputStream.read()方法。这个方法是从流里每次只读取读取一个字节,效率会非常低。 更好的方法是用InputStream.read(byte[] b)或者InputStream.read(byte[] b,int off,int len)方法,一次读取多个字节。

2. 关于InputStream类的available()方法

要一次读取多个字节时,经常用到InputStream.available()方法,这个方法可以在读写操作前先得知数据流里有多少个字节可以读取。需要注意的是,如果这个方法用在从本

地文件读取数据时,一般不会遇到问题,但如果是用于网络操作,就经常会遇到一些麻烦。比如,Socket通讯时,对方明明发来了1000个字节,但是自己的程序调用available()方法却只得到900,或者100,甚至是0,感觉有点莫名其妙,怎么也找不到原因。其实,这是因为网络通讯往往是间断性的,一串字节往往分几批进行发送。本地程序调用available()方法有时得到0,这可能是对方还没有响应,也可能是对方已经响应了,但是数据还没有送达本地。对方发送了1000个字节给你,也许分成3批到达,这你就要调用3次available()方法才能将数据总数全部得到。

如果这样写代码:

 

 
  1. int count = in.available(); 
  2. byte[] b = new byte[count]; 
  3. in.read(b); 

在进行网络操作时往往出错,因为你调用available()方法时,对发发送的数据可能还没有到达,你得到的count是0。

需要改成这样:

 

 
  1. int count = 0; 
  2. while (count == 0) { 
  3. count = in.available(); 
  4. byte[] b = new byte[count]; 
  5. in.read(b); 

3. 关于InputStream.read(byte[] b)和InputStream.read(byte[] b,int off,int len)

这两个方法都是用来从流里读取多个字节的,有经验的程序员就会发现,这两个方法经常 读取不到自己想要读取的个数的字节。比如第一个方法,程序员往往希望程序能读取到b.length个字节,而实际情况是,系统往往读取不了这么多。仔细阅读Java的API说明就发现了,这个方法 并不保证能读取这么多个字节,它只能保证最多读取这么多个字节(最少1个)。因此,如果要让程序读取count个字节,最好用以下代码:

 

 
  1. byte[] b = new byte[count]; 
  2. int readCount = 0; // 已经成功读取的字节的个数 
  3. while (readCount < count) { 
  4. readCount += in.read(bytes, readCount, count - readCount); 

用这段代码可以保证读取count个字节,除非中途遇到IO异常或者到了数据流的结尾(EOFException)

4.读取PowerPoint文件的例子

 

 
  1. import java.io.InputStream;  
  2.  
  3. import org.apache.lucene.document.Document;  
  4. import org.apache.poi.hslf.HSLFSlideShow;  
  5. import org.apache.poi.hslf.model.TextRun;  
  6. import org.apache.poi.hslf.model.Slide;  
  7. import org.apache.poi.hslf.usermodel.SlideShow;  
  8.  
  9. public Document getDocument(Index index, String url, String title, InputStream is)  
  10. throws DocCenterException {  
  11. StringBuffer content = new StringBuffer("");  
  12. try{  
  13. SlideShow ss = new SlideShow(new HSLFSlideShow(is));//is 为文件的InputStream,建立SlideShow  
  14. Slide[] slides = ss.getSlides();//获得每一张幻灯片  
  15. for(int i=0;i<slides.length;i++){  
  16. TextRun[] t = slides[i].getTextRuns();//为了取得幻灯片的文字内容,建立TextRun  
  17. for(int j=0;j<t.length;j++){  
  18. content.append(t[j].getText());//这里会将文字内容加到content中去  
  19. }  
  20. content.append(slides[i].getTitle());  
  21. }  
  22. index.AddIndex(url, title, content.toString());  
  23. }catch(Exception ex){  
  24. System.out.println(ex.toString());  
  25. }  
  26. return null;  


注:相关教程知识阅读请移步到JAVA教程频道。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表