`
2277259257
  • 浏览: 499115 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

web开发总结----word的写入、读取

 
阅读更多

以下是Java对几种文本文件内容读取代码。其中,OFFICE文档(WORD,EXCEL)使用了POI控件,PDF使用了PDFBOX控件。

 点击这里查看相关控件的下载地址和配置方法。

 

 

  WORD

Java代码
  1. package textReader;   
  2. import java.io.*;   
  3. import org.apache.poi.hwpf.extractor.WordExtractor;   
  4.   
  5. public class WordReader {   
  6.     public WordReader(){   
  7.     }   
  8.     /**  
  9.      * @param filePath 文件路径  
  10.      * @return 读出的Word的内容  
  11.      */  
  12.     public String getTextFromWord(String filePath){   
  13.         String result = null;   
  14.         File file = new File(filePath);   
  15.         try{   
  16.             FileInputStream fis = new FileInputStream(file);   
  17.             WordExtractor wordExtractor = new WordExtractor(fis);   
  18.             result = wordExtractor.getText();   
  19.         }catch(FileNotFoundException e){   
  20.             e.printStackTrace();   
  21.         }catch(IOException e){   
  22.             e.printStackTrace();   
  23.         };   
  24.         return result;   
  25.     }   
  26. }    

  EXCEL

Java代码
  1. package textReader;   
  2. import org.apache.poi.hssf.usermodel.HSSFWorkbook;   
  3. import org.apache.poi.hssf.usermodel.HSSFSheet;   
  4. import org.apache.poi.hssf.usermodel.HSSFRow;   
  5. import org.apache.poi.hssf.usermodel.HSSFCell;   
  6.   
  7. import java.io.FileInputStream;   
  8. import java.io.FileNotFoundException;   
  9. import java.io.IOException;   
  10.   
  11.   
  12. public class ExcelReader {   
  13.   
  14.     @SuppressWarnings("deprecation")   
  15.     /**  
  16.      * @param filePath 文件路径  
  17.      * @return 读出的Excel的内容  
  18.      */  
  19.     public String getTextFromExcel(String filePath) {   
  20.         StringBuffer buff = new StringBuffer();   
  21.         try {   
  22.             //创建对Excel工作簿文件的引用   
  23.             HSSFWorkbook wb = new HSSFWorkbook(new FileInputStream(filePath));   
  24.             //创建对工作表的引用。           
  25.             for (int numSheets = 0; numSheets < wb.getNumberOfSheets(); numSheets++) {   
  26.                 if (null != wb.getSheetAt(numSheets)) {   
  27.                     HSSFSheet aSheet = wb.getSheetAt(numSheets);//获得一个sheet   
  28.                     for (int rowNumOfSheet = 0; rowNumOfSheet <= aSheet.getLastRowNum(); rowNumOfSheet++) {   
  29.                         if (null != aSheet.getRow(rowNumOfSheet)) {   
  30.                             HSSFRow aRow = aSheet.getRow(rowNumOfSheet); //获得一个行   
  31.                             for (int cellNumOfRow = 0; cellNumOfRow <= aRow.getLastCellNum(); cellNumOfRow++) {   
  32.                                 if (null != aRow.getCell(cellNumOfRow)) {   
  33.                                     HSSFCell aCell = aRow.getCell(cellNumOfRow);//获得列值   
  34.                                     switch(aCell.getCellType()){   
  35.                                         case HSSFCell.CELL_TYPE_FORMULA:   
  36.                                             break;    
  37.                                         case HSSFCell.CELL_TYPE_NUMERIC:   
  38.                                             buff.append(aCell.getNumericCellValue()).append('\t');break;   
  39.                                         case HSSFCell.CELL_TYPE_STRING:   
  40.                                             buff.append(aCell.getStringCellValue()).append('\t');break;                                                                
  41.                                 }                              
  42.                         }                                                                                   
  43.                     }   
  44.                     buff.append('\n');   
  45.                     }   
  46.                 }                                         
  47.             }              
  48.         }   
  49.         } catch (FileNotFoundException e) {   
  50.             e.printStackTrace();   
  51.         } catch (IOException e) {   
  52.             e.printStackTrace();   
  53.         }   
  54.         return buff.toString();   
  55.     }               
  56. }   
 

  PDF  

Java代码
  1. package textReader;   
  2. import java.io.FileInputStream;   
  3. import java.io.FileNotFoundException;   
  4. import java.io.IOException;   
  5.   
  6. import org.pdfbox.pdfparser.PDFParser;   
  7. import org.pdfbox.pdmodel.PDDocument;   
  8. import org.pdfbox.util.PDFTextStripper;   
  9.   
  10.   
  11. public class PdfReader {   
  12.     public PdfReader(){   
  13.     }   
  14.     /**  
  15.      * @param filePath 文件路径  
  16.      * @return 读出的pdf的内容  
  17.      */  
  18.     public String getTextFromPdf(String filePath) {   
  19.         String result = null;   
  20.         FileInputStream is = null;   
  21.         PDDocument document = null;   
  22.         try {   
  23.             is = new FileInputStream(filePath);   
  24.             PDFParser parser = new PDFParser(is);   
  25.             parser.parse();   
  26.             document = parser.getPDDocument();   
  27.             PDFTextStripper stripper = new PDFTextStripper();   
  28.             result = stripper.getText(document);   
  29.         } catch (FileNotFoundException e) {   
  30.             e.printStackTrace();   
  31.         } catch (IOException e) {   
  32.             e.printStackTrace();   
  33.         } finally {   
  34.             if (is != null) {   
  35.                 try {is.close();}catch(IOException e){e.printStackTrace();}   
  36.             }   
  37.             if (document != null) {   
  38.                 try{document.close();}catch (IOException e){e.printStackTrace();}   
  39.             }   
  40.         }   
  41.         return result;   
  42.     }   
  43.   
  44. }  

  TXT

Java代码
  1. package textReader;   
  2. import java.io.*;   
  3.   
  4.   
  5. public class TxtReader {   
  6.     public TxtReader() {           
  7.     }   
  8.     /**  
  9.      * @param filePath 文件路径  
  10.      * @return 读出的txt的内容  
  11.      */  
  12.     public String getTextFromTxt(String filePath) throws Exception {   
  13.            
  14.         FileReader fr = new FileReader(filePath);   
  15.         BufferedReader br = new BufferedReader(fr);   
  16.         StringBuffer buff = new StringBuffer();   
  17.         String temp = null;   
  18.         while((temp = br.readLine()) != null){   
  19.             buff.append(temp + "\r\n");   
  20.         }   
  21.         br.close();        
  22.         return buff.toString();        
  23.     }   
  24. }  

RTF

Java代码
  1. package textReader;   
  2. import java.io.File;   
  3. import java.io.FileInputStream;   
  4. import java.io.IOException;   
  5. import java.io.InputStream;   
  6.   
  7. import javax.swing.text.BadLocationException;   
  8. import javax.swing.text.DefaultStyledDocument;   
  9. import javax.swing.text.rtf.RTFEditorKit;   
  10.   
  11.   
  12. public class RtfReader {   
  13.     public RtfReader(){   
  14.     }   
  15.     /**  
  16.      * @param filePath 文件路径  
  17.      * @return 读出的rtf的内容  
  18.      */  
  19.     public String getTextFromRtf(String filePath) {   
  20.         String result = null;   
  21.         File file = new File(filePath);   
  22.         try {          
  23.             DefaultStyledDocument styledDoc = new DefaultStyledDocument();   
  24.             InputStream is = new FileInputStream(file);   
  25.             new RTFEditorKit().read(is, styledDoc, 0);   
  26.             result = new String(styledDoc.getText(0,styledDoc.getLength()).getBytes("ISO8859_1"));   
  27.             //提取文本,读取中文需要使用ISO8859_1编码,否则会出现乱码   
  28.         } catch (IOException e) {   
  29.             e.printStackTrace();   
  30.         } catch (BadLocationException e) {   
  31.             e.printStackTrace();   
  32.         }   
  33.         return result;   
  34.     }   
  35.        
  36. }  

   HTML

Java代码
  1. package textReader;   
  2. import java.io.*;   
  3.   
  4. public class HtmlReader {   
  5.     public HtmlReader() {   
  6.     }   
  7.     /**  
  8.      * @param filePath 文件路径  
  9.      * @return 获得html的全部内容  
  10.      */  
  11.     public String readHtml(String filePath) {   
  12.         BufferedReader br=null;   
  13.         StringBuffer sb = new  StringBuffer();   
  14.         try {   
  15.             br=new BufferedReader(new InputStreamReader(new FileInputStream(filePath),  "GB2312"));            
  16.             String temp=null;          
  17.             while((temp=br.readLine())!=null){   
  18.                 sb.append(temp);   
  19.             }              
  20.         } catch (FileNotFoundException e) {   
  21.             e.printStackTrace();   
  22.         } catch (IOException e) {   
  23.             e.printStackTrace();   
  24.         }   
  25.         return sb.toString();   
  26.     }   
  27.     /**  
  28.      * @param filePath 文件路径  
  29.      * @return 获得的html文本内容  
  30.      */  
  31.     public String getTextFromHtml(String filePath) {   
  32.         //得到body标签中的内容   
  33.         String str= readHtml(filePath);   
  34.         StringBuffer buff = new StringBuffer();   
  35.         int maxindex = str.length() - 1;   
  36.         int begin = 0;   
  37.         int end;               
  38.         //截取>和<之间的内容   
  39.         while((begin = str.indexOf('>',begin)) < maxindex){              
  40.             end = str.indexOf('<',begin);   
  41.             if(end - begin > 1){   
  42.                 buff.append(str.substring(++begin, end));                  
  43.             }              
  44.             begin = end+1;   
  45.         };         
  46.         return buff.toString();   
  47.     }   
  48.   
  49. }  
分享到:
评论

相关推荐

    PHPWord,可以自动生成doc文档

    PHPWord,可以自动生成doc文档,比如用户在web上输入信息,点击下载,即可根据用户的选择生成对应的文档,以供用户下载。

    基于opencv3.1库的JAVA源码

    范例4-1-1 Opencv读取写入练习 79 范例4-1-2 Opencv读取影像并显示至视窗 81 范例4-1-3 Opencv读取影像显示至视窗-版本2 84 范例4-1-4影像储存压缩品质选择 87 范例4-2-1 Opencv使用webcam拍照,并存放置资料匣 89 ...

    JAVA上百实例源码以及开源项目

    此时此景,笔者只专注Android、Iphone等移动平台开发,看着这些源码心中有万分感慨,写此文章纪念那时那景! Java 源码包 Applet钢琴模拟程序java源码 2个目标文件,提供基本的音乐编辑功能。编辑音乐软件的朋友,这...

    java开源包1

    缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java...

    php网络开发完全手册

    1.6 几种开发工具的介绍 20 1.6.1 Vi及Vim 20 1.6.2 Eclipse+PHPEclipse插件 21 1.6.3 UltraEdit 21 1.6.4 EditPlus 22 1.6.5 支持PHP的IDE环境 22 1.7 小结 23 第2章 PHP的基础语法 24 2.1 语言构成与工作原理 24 ...

    java开源包10

    缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java...

    ActionScript开发人员指南中文版

    actionScript 3.0开发人员指南中文版,总共67章,955页。学习actionScript不错的书籍。 目录: 目录 第章:使用日期和时间 管理日历日期和时间 控制时间间隔 日期和时间示例:简单模拟时钟 第章:使用字符串 字符串...

    Visual C++程序开发范例宝典(PDF扫描版).part3

     cc实例227 对SQLcServer数据库进行录入和存储Word文档   8.10 数据备份恢复   cc实例228 Access数据库备份与还原   cc实例229 SQLcServer数据库备份与恢复   cc实例230 定时数据备份   8.11 其他...

    Visual C++ 程序开发范例宝典 源码 光盘 part2

    8.8 数据库结构的读取与修改 cc实例223 读取Access数据库结构 cc实例224 读取SQLcServer数据库结构 8.9 图片.c多媒体数据录入技术 cc 实例225 对Access数据库进行录入和提取图片 cc实例226 对SQLServer...

    计算机应用基础E卷.doc

    执行 读取 脚本 写入 存放在外存上的数据,________。 CPU可直接访问 关机后会丢失 CPU访问前必须先装入内存 是高速缓冲存储器中的信息 在OSI七层结构模型中,最低层是________。 会话层 表示层 物理层 网络层 能...

    Visual C++程序开发范例宝典(PDF扫描版).part2

     cc实例227 对SQLcServer数据库进行录入和存储Word文档   8.10 数据备份恢复   cc实例228 Access数据库备份与还原   cc实例229 SQLcServer数据库备份与恢复   cc实例230 定时数据备份   8.11 其他...

    C#程序开发范例宝典(第2版).part08

    一部久享盛誉的程序开发宝典。精选570个典型范例,全面覆盖实用和热点技术,涉及面广,实用性强源于实际项目开发,帮助读者短时间掌握更多实用技术,提高编程水平范例经过精心编排,重点、难点突出,易学易懂书后...

    C#程序开发范例宝典(第2版).part12

    一部久享盛誉的程序开发宝典。精选570个典型范例,全面覆盖实用和热点技术,涉及面广,实用性强源于实际项目开发,帮助读者短时间掌握更多实用技术,提高编程水平范例经过精心编排,重点、难点突出,易学易懂书后...

    java开源包11

    缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java...

    java开源包2

    缓存读取自redis的slave节点,写入到redis的master节点。 Java对象的SQL接口 JoSQL JoSQL(SQLforJavaObjects)为Java开发者提供运用SQL语句来操作Java对象集的能力.利用JoSQL可以像操作数据库中的数据一样对任何Java...

    NTKO文档在线编辑控件4.0.1.2

    NTKO OFFICE文档控件能够在浏览器窗口中直接编辑Word,Excel,Wps等Office文档并保存到任意Web服务器。实现文档和电子表格的统一管理。同时支持强制痕迹保留,手写签名,电子印章,版本控制,附件上传等办公自动化系统...

Global site tag (gtag.js) - Google Analytics