0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Camelot:Python超強(qiáng)大的PDF表格提取器

科技綠洲 ? 來源:Python實(shí)用寶典 ? 作者:Python實(shí)用寶典 ? 2023-10-21 10:57 ? 次閱讀

如果你有從PDF中批量提取表格的需求,那么這篇文章就是你的福音。

Python 第三方模塊 Camelot 能夠精準(zhǔn)識(shí)別PDF中的表格信息,并提取為pandas數(shù)據(jù)結(jié)構(gòu),而且還能導(dǎo)出為多種格式:JSON,Excel,HTML和Sqlite。

下面給大家介紹這個(gè)模塊的使用方法:

1.準(zhǔn)備

開始之前,你要確保Python和pip已經(jīng)成功安裝在電腦上,如果沒有,可以訪問這篇文章:超詳細(xì)Python安裝指南 進(jìn)行安裝。

如果你用Python的目的是數(shù)據(jù)分析,可以直接安裝Anaconda:Python數(shù)據(jù)分析與挖掘好幫手—Anaconda,它內(nèi)置了Python和pip.

此外,推薦大家用VSCode編輯器,它有許多的優(yōu)點(diǎn):Python 編程的最好搭檔—VSCode 詳細(xì)指南

請選擇以下任一種方式輸入命令安裝依賴

  1. Windows 環(huán)境 打開 Cmd (開始-運(yùn)行-CMD)。
  2. MacOS 環(huán)境 打開 Terminal (command+空格輸入Terminal)。
  3. 如果你用的是 VSCode編輯器 或 Pycharm,可以直接使用界面下方的Terminal.
pip install camelot-py[cv]

2.使用

最簡單的使用方式如下:

import camelot
# 1.讀取pdf
tables = camelot.read_pdf('foo.pdf', flavor='stream')
# 2.導(dǎo)出pdf所有的表格為csv文件
tables.export('foo.csv', f='csv') # json, excel, html, sqlite

第一行,導(dǎo)入了camelot這個(gè)模塊。

第二行,以stream的模式讀取當(dāng)前目錄的foo.pdf文件。

第三行,將所有表格數(shù)據(jù)導(dǎo)出為 foo.csv 文件,并保存在當(dāng)前文件夾下。

相當(dāng)簡單,請注意,read_pdf 的 flavor 參數(shù)是可選的,如果你不帶這個(gè)參數(shù),請注意需要安裝 ghostscript 這個(gè)驅(qū)動(dòng),因?yàn)樗J(rèn)使用 ghostscript 去用 lattice 模式。

3.進(jìn)階

3.1 處理背景線:

圖片

可以看到,很多表格的線都隱藏在背景中。這種表格默認(rèn)是不支持的,這時(shí)候我們需要讓程序能夠自動(dòng)識(shí)別這樣的表格:

tables = camelot.read_pdf('background_lines.pdf', process_background=True)

增加 process_background=True 參數(shù)即可。

3.2 指定表格區(qū)域

某些情況下無法正確識(shí)別到PDF中的表格,此時(shí)手動(dòng)設(shè)定左上角和右下角的邊界可能是有效果的:

tables = camelot.read_pdf('table_areas.pdf', flavor='stream', table_areas=['316,499,566,337'])

其中 table_areas 接受格式為 x1,y1,x2,y2 的字符串,其中(x1,y1) -> 左上角, (x2,y2) -> 右下角。在PDF坐標(biāo)空間中,頁面的左下角是原點(diǎn),坐標(biāo)為(0,0)。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 數(shù)據(jù)結(jié)構(gòu)

    關(guān)注

    3

    文章

    573

    瀏覽量

    40169
  • python
    +關(guān)注

    關(guān)注

    56

    文章

    4801

    瀏覽量

    84878
  • 提取器
    +關(guān)注

    關(guān)注

    0

    文章

    14

    瀏覽量

    8124
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    基于python讀取excel表格

    Python:利用python讀取excel表格的那些七七八八事
    發(fā)表于 12-28 14:23

    2021年度python13本電子書單含源碼PDF電子版百度網(wǎng)盤下載

    2021年度python書單PDF電子版下載鏈接:https://pan.baidu.com/s/10bR41hpAXpsWZWkbSPxaRA提取碼:cn85
    發(fā)表于 05-08 15:45

    python教程之如何使用XlsxWriter模塊創(chuàng)建aexcel表格

    本文檔的主要內(nèi)容詳細(xì)介紹的是python教程之如何使用XlsxWriter模塊創(chuàng)建aexcel表格
    發(fā)表于 01-18 17:01 ?10次下載
    <b class='flag-5'>python</b>教程之如何使用XlsxWriter模塊創(chuàng)建aexcel<b class='flag-5'>表格</b>

    使用Python操作excel表格的xlrd介紹

    本文檔的主要內(nèi)容詳細(xì)介紹的是使用Python操作excel表格的xlrd介紹。
    發(fā)表于 07-02 08:00 ?2次下載

    Python編程入門》.pdf

    Python編程入門》.pdf
    發(fā)表于 02-11 16:03 ?0次下載

    如何使用OpenCV和Python從圖像中提取感興趣區(qū)域

    今天我們將一起探究如何使用OpenCV和Python從圖像中提取感興趣區(qū)域(ROI)。 在之間的文章中,我們完成了圖像邊緣提取,例如從臺(tái)球桌中提取桌邊。使用了簡單的OpenC
    的頭像 發(fā)表于 02-07 14:42 ?1870次閱讀

    PythonPDF表格提取-Camelot

    Python 第三方模塊 Camelot 能夠精準(zhǔn)識(shí)別PDF中的表格信息,并提取為pandas數(shù)據(jù)結(jié)構(gòu),而且還能導(dǎo)出為多種格式:JSON,E
    的頭像 發(fā)表于 02-24 11:04 ?2233次閱讀
    <b class='flag-5'>Python</b>的<b class='flag-5'>PDF</b><b class='flag-5'>表格</b><b class='flag-5'>提取</b><b class='flag-5'>器</b>-<b class='flag-5'>Camelot</b>

    如何提取Word文檔表格保存到Excel

    據(jù)提取到Excel表中。例如,提取word文檔中的財(cái)務(wù)數(shù)據(jù)、考勤數(shù)據(jù)等,將數(shù)據(jù)存儲(chǔ)到 Excel表中,本次項(xiàng)目我們專門針對word文檔中的表格數(shù)據(jù)進(jìn)行解析與提取。
    的頭像 發(fā)表于 02-24 16:00 ?2850次閱讀
    如何<b class='flag-5'>提取</b>Word文檔<b class='flag-5'>表格</b>保存到Excel

    只需2行代碼,輕松將PDF轉(zhuǎn)換成Word

    可將 PDF 轉(zhuǎn)換成 docx 文件的 Python 庫。該項(xiàng)目通過 PyMuPDF 庫提取 PDF 文件中的數(shù)據(jù),然后采用 python-
    的頭像 發(fā)表于 05-08 14:23 ?1025次閱讀
    只需2行代碼,輕松將<b class='flag-5'>PDF</b>轉(zhuǎn)換成Word

    Python教你用 Rows 快速操作csv文件

    , 我認(rèn)為 Rows 的優(yōu)勢在于其易于理解的計(jì)算語法和各種方便的導(dǎo)出和轉(zhuǎn)換語法。它能非常方便地提取pdf中的文字、將csv轉(zhuǎn)換為sqlite文件、合并csv等,還能對csv文件執(zhí)行sql語法,還是比較強(qiáng)大
    的頭像 發(fā)表于 10-21 10:18 ?639次閱讀

    Camelot超強(qiáng)大PDF表格提取

    如果你有從PDF中批量提取表格的需求,那么這篇文章就是你的福音。 Python 第三方模塊 Camelot 能夠精準(zhǔn)識(shí)別
    的頭像 發(fā)表于 10-30 09:44 ?1067次閱讀
    <b class='flag-5'>Camelot</b>:<b class='flag-5'>超強(qiáng)大</b>的<b class='flag-5'>PDF</b><b class='flag-5'>表格</b><b class='flag-5'>提取</b><b class='flag-5'>器</b>

    Newspaper:用于提取和整理文章的python

    Newspaper 是一個(gè)很棒的python庫,用于提取和整理文章。 它有以下的優(yōu)點(diǎn): 多線程文章下載框架 識(shí)別新聞網(wǎng)址 從html提取文本 從html提取頂部圖像 從html
    的頭像 發(fā)表于 10-30 14:24 ?780次閱讀

    Camelot模塊的使用方法

    如果你有從PDF中批量提取表格的需求,那么這篇文章就是你的福音。 Python 第三方模塊 Camelot 能夠精準(zhǔn)識(shí)別
    的頭像 發(fā)表于 11-01 10:02 ?1071次閱讀
    <b class='flag-5'>Camelot</b>模塊的使用方法

    Python中Excel轉(zhuǎn)PDF的實(shí)現(xiàn)步驟

    將Excel文件轉(zhuǎn)換為PDF可以方便儲(chǔ)存表格數(shù)據(jù),此外在打印或共享文檔時(shí)也能確保表格樣式布局等在不同設(shè)備和操作系統(tǒng)上保持一致。今天給大家分享一個(gè)使用第三方Python庫Spire.XL
    的頭像 發(fā)表于 11-20 15:02 ?1201次閱讀
    <b class='flag-5'>Python</b>中Excel轉(zhuǎn)<b class='flag-5'>PDF</b>的實(shí)現(xiàn)步驟

    python如何遍歷列表并提取

    遍歷列表是Python中非常常見的操作之一,可以使用for循環(huán)或者while循環(huán)來實(shí)現(xiàn)。下面我將詳細(xì)介紹如何使用for循環(huán)遍歷列表并提取元素。 首先,讓我們簡單了解一下Python中的列表。列表
    的頭像 發(fā)表于 11-23 15:55 ?1464次閱讀