用Java讀取pdf中的資料

來源:互聯網
上載者:User
用Java簡單的讀取pdf檔案中的資料:第一步:下載PDFBox-0.7.2.jar。提供一個:http://pdfhome.hope.com.cn/Resource.aspx?CID=63844604-5253-4ae1-b023-258c9e324061&RID=20cd8f94-1cee-40b6-a3df-0ef024f8e0d2解壓後,把lib檔案下的PDFBox-0.7.2.jar,PDFBox-0.7.2-log4j.jar放到你classpath路徑下。(我把源碼以及jar包都放到下面的附件裡,方面你的使用。)第二步:寫個簡單的讀取pdf檔案的程式。(PdfReader.java)import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStreamWriter;
import java.io.Writer;
import java.net.MalformedURLException;
import java.net.URL;
import org.pdfbox.pdmodel.PDDocument;
import org.pdfbox.util.PDFTextStripper;public class PdfReader { public void readFdf(String file) throws Exception {
  // 是否排序
  boolean sort = false;
  // pdf檔案名稱
  String pdfFile = file;
  // 輸入文字檔名稱
  String textFile = null;
  // 編碼方式
  String encoding = "UTF-8";
  // 開始提取頁數
  int startPage = 1;
  // 結束提取頁數
  int endPage = Integer.MAX_VALUE;
  // 檔案輸入資料流,產生文字檔
  Writer output = null;
  // 記憶體中儲存的PDF Document
  PDDocument document = null;
  try {
   try {
    // 首先當作一個URL來裝載檔案,如果得到異常再從本地檔案系統//去裝載檔案
    URL url = new URL(pdfFile);   //注意參數已不是以前版本中的URL.而是File。
    document = PDDocument.load(pdfFile);
    // 擷取PDF的檔案名稱
    String fileName = url.getFile();
    // 以原來PDF的名稱來命名新產生的txt檔案
    if (fileName.length() > 4) {
     File outputFile = new File(fileName.substring(0, fileName
       .length() - 4)
       + ".txt");
     textFile = outputFile.getName();
    }
   } catch (MalformedURLException e) {
    // 如果作為URL裝載得到異常則從檔案系統裝載   //注意參數已不是以前版本中的URL.而是File。
    document = PDDocument.load(pdfFile);
    if (pdfFile.length() > 4) {     textFile = pdfFile.substring(0, pdfFile.length() - 4)
       + ".txt";
    }
   }
   // 檔案輸入資料流,寫入檔案倒textFile
   output = new OutputStreamWriter(new FileOutputStream(textFile),
     encoding);
   // PDFTextStripper來提取文本
   PDFTextStripper stripper = null;
   stripper = new PDFTextStripper();
   // 設定是否排序
   stripper.setSortByPosition(sort);
   // 設定起始頁
   stripper.setStartPage(startPage);
   // 設定結束頁
   stripper.setEndPage(endPage);
   // 調用PDFTextStripper的writeText提取並輸出文本
   stripper.writeText(document, output);
  } finally {
   if (output != null) {
    // 關閉輸出資料流
    output.close();
   }
   if (document != null) {
    // 關閉PDF Document
    document.close();
   }
  }
 } /**
  * @param args
  */
 public static void main(String[] args) {
  // TODO Auto-generated method stub
  PdfReader pdfReader = new PdfReader();
  try {
   // 取得E盤下的SpringGuide.pdf的內容
   pdfReader.readFdf("E://SpringGuide.pdf");
  } catch (Exception e) {
   e.printStackTrace();
  }
 }}   這樣就簡單的完成了從pdf中讀取資料了。在你的pdf檔案所在的目錄下產生一個同名的txt檔案。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.