[PYTHON] In Google Colaboratory registrierte Snippets (PDF-Textkonvertierung)

PDF-Textkonvertierung

pdfminer

Befehl

!pip install pdfminer.six
!python /usr/local/bin/pdf2txt.py -o data.txt data.pdf

Python

from pdfminer.high_level import extract_text

text = extract_text("data.pdf")

pdfbox

Befehl

#Die URL ändert sich mit der neuesten Version
!wget https://www-eu.apache.org/dist/pdfbox/2.0.21/pdfbox-app-2.0.21.jar -O pdfbox-app.jar

#Textkonvertierung
!java -jar pdfbox-app.jar ExtractText -sort -encoding UTF-8 data.pdf

#Bild
!java -jar pdfbox-app.jar PDFToImage -imageType png -dpi 300 data.pdf

Python

!pip install python-pdfbox

import pdfbox

p = pdfbox.PDFBox()
p.extract_text("data.pdf", sort=True)

poppler

Befehl

!apt install poppler-utils poppler-data

#Textkonvertierung
!pdftotext -layout data.pdf

!pdfinfo data.pdf

#Reparatur
!pdftocairo -pdf data.pdf data_repaired.pdf

PDF-Tabellenkonvertierung

tabula

Befehl

!wget https://github.com/tabulapdf/tabula-java/releases/download/v1.0.4/tabula-1.0.4-jar-with-dependencies.jar -O tabula.jar

# lattice
!java -jar tabula.jar -o data.csv -p all -l data.pdf

# stream
!java -jar tabula.jar -o data.csv -p all -t data.pdf

Python

!pip install tabula-py

import pandas as pd
from tabula import read_pdf

dfs = read_pdf("data.pdf", pages="all", lattice=True)

dfs = read_pdf("data.pdf", pages="all", lattice=True, pandas_options={"header": None})

Camelot

Befehl

!apt install python3-tk ghostscript
!pip install camelot-py[cv]

# !pip install camelot-py[plot]

# !camelot --help

!camelot -p all -o data.csv -f csv lattice data.pdf

!camelot -p all -o data.csv -f csv -strip ' .\n' -split lattice -scale 40 data.pdf

Python

import camelot

tables = camelot.read_pdf("data.pdf", pages="all", split_text=True, strip_text=" \n", line_scale=40)

pdfplumber

!pip install pdfplumber
!apt install libmagickwand-dev ghostscript
#Um PDF in Bild konvertieren zu können/etc/ImageMagick-6/policy.XML überschreiben
%%writefile /etc/ImageMagick-6/policy.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE policymap>

<policymap>

  <policy domain="resource" name="memory" value="256MiB"/>
  <policy domain="resource" name="map" value="512MiB"/>
  <policy domain="resource" name="width" value="16KP"/>
  <policy domain="resource" name="height" value="16KP"/>
  <policy domain="resource" name="area" value="128MB"/>
  <policy domain="resource" name="disk" value="1GiB"/>

  <policy domain="delegate" rights="none" pattern="URL"/>
  <policy domain="delegate" rights="none" pattern="HTTPS"/>
  <policy domain="delegate" rights="none" pattern="HTTP"/>

  <policy domain="path" rights="none" pattern="@*"/>
  <policy domain="cache" name="shared-secret" value="passphrase" stealth="true"/>

  <policy domain="coder" rights="none" pattern="PS"/>
  <policy domain="coder" rights="none" pattern="PS2"/>
  <policy domain="coder" rights="none" pattern="PS3"/>
  <policy domain="coder" rights="none" pattern="EPS"/>
  <policy domain="coder" rights="read|write" pattern="PDF" />
  <policy domain="coder" rights="none" pattern="XPS"/>
</policymap>
!pdfplumber < data.pdf > data.csv

import pdfplumber
import pandas as pd

pdf = pdfplumber.open("data.pdf")

page = pdf.pages[0]

page.find_tables()[0]

#Überprüfen Sie die Position der Zeichen
page.chars

#Holen Sie sich Text mit Zuschneiden
crop = page.within_bbox((0, 90, p0.width, 105))

s = crop.extract_text()
s

#PDF-Bestätigung
im = page.to_image()
im

table_settings = {

    #Vertikale Referenz
    "vertical_strategy": "lines",
    #Geben Sie das vertikale Trennzeichen numerisch an (Liste)
    "explicit_vertical_lines": [],

    #Horizontale Referenz
    "horizontal_strategy": "lines",
    #Geben Sie die horizontale Unterteilung numerisch an (Liste)
    "explicit_horizontal_lines": [],

    #Wenn es innerhalb des zulässigen Bereichs liegt, stellen Sie es auf dieselbe horizontale oder vertikale Position ein. * Oben einstellen?
    "snap_tolerance": 3,

    #Wenn innerhalb der Toleranz, treten Sie bei
    "join_tolerance": 3,

    #Kürzere Kanten als zerstört, bevor versucht wird, den Tisch wieder aufzubauen?
    "edge_min_length": 3,

    #Minimale Zeichenhöhe
    "min_words_vertical": 3,

    #Minimale Zeichenhöhe
    "min_words_horizontal": 1,

    #Erkennen Sie leere Zeichen als Teil eines Wortes und verwenden Sie sie nicht als Trennzeichen
    "keep_blank_chars": False,

    #Wird als Wort erkannt, wenn der Zeichenabstand wie folgt ist
    "text_tolerance": 3,
    "text_x_tolerance": None,
    "text_y_tolerance": None,
    
    #Toleranz, wenn der linke und der rechte Rand des Textes nicht genau mit den vertikalen Linien übereinstimmen?
    "intersection_tolerance": 3,
    "intersection_x_tolerance": None,
    "intersection_y_tolerance": None,
}

#Zeichenbestätigung
im.reset().draw_rects(page.extract_words())

#Überprüfen Sie die Tabelle
im.reset().debug_tablefinder()

with pdfplumber.open("data.pdf") as pdf:

    dfs = []

    for page in pdf.pages:

        table = page.extract_table(table_settings)

        df_tmp = pd.DataFrame(table[1:], columns=table[0])

        dfs.append(df_tmp)

df = pd.concat(dfs)

OCR

tesseract-ocr

!add-apt-repository ppa:alex-p/tesseract-ocr -y
!apt update
!apt install tesseract-ocr
!apt install libtesseract-dev
!tesseract -v

!apt install tesseract-ocr-jpn  tesseract-ocr-jpn-vert
!apt install tesseract-ocr-script-jpan tesseract-ocr-script-jpan-vert
!tesseract --list-langs
!pip install pytesseract

try:
    from PIL import Image
except ImportError:
    import Image
    
import pytesseract

import cv2
import numpy as np

from google.colab.patches import cv2_imshow

img = cv2.imread("test.jpg ")

#Schwarz-Weiß-Inversion
img_gray, _ = cv2.decolor(img)

cv2_imshow(img_gray)

Recommended Posts

In Google Colaboratory registrierte Snippets (PDF-Textkonvertierung)
In Google Colaboratory registrierte Snippets (Scraping)
Google-Labor
Verwenden Sie Cartopy mit Google Colaboratory, ohne an Fehlern zu leiden
Fügen Sie in Python gekratzten Text in eine Google-Tabelle ein
So laden Sie Dateien in Google Drive mit Google Colaboratory
Verwendung des japanischen Spacy-Modells mit Google Colaboratory
Ich kann den Darknet-Befehl in Google Colaboratory nicht verwenden!