forked from jsvine/pdfplumber
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_laparams.py
47 lines (38 loc) · 1.58 KB
/
test_laparams.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
#!/usr/bin/env python
import unittest
import pdfplumber
import os
import logging
logging.disable(logging.ERROR)
HERE = os.path.abspath(os.path.dirname(__file__))
class Test(unittest.TestCase):
@classmethod
def setup_class(self):
self.path = os.path.join(HERE, "pdfs/issue-13-151201DSP-Fond-581-90D.pdf")
def test_without_laparams(self):
with pdfplumber.open(self.path, laparams=None) as pdf:
objs = pdf.pages[0].objects
assert "textboxhorizontal" not in objs.keys()
assert len(objs["char"]) == 4408
def test_with_laparams(self):
with pdfplumber.open(self.path, laparams={}) as pdf:
page = pdf.pages[0]
assert len(page.textboxhorizontals) == 21
assert len(page.textlinehorizontals) == 79
assert len(page.chars) == 4408
assert "anno" not in page.objects.keys()
def test_vertical_texts(self):
path = os.path.join(HERE, "pdfs/issue-192-example.pdf")
laparams = {"detect_vertical": True}
with pdfplumber.open(path, laparams=laparams) as pdf:
page = pdf.pages[0]
assert len(page.textlinehorizontals) == 142
assert len(page.textboxhorizontals) == 74
assert len(page.textlineverticals) == 11
assert len(page.textboxverticals) == 6
def test_issue_383(self):
with pdfplumber.open(self.path, laparams={}) as pdf:
p0 = pdf.pages[0]
assert "anno" not in p0.objects.keys()
cropped = p0.crop((0, 0, 100, 100))
assert len(cropped.objects)