Skip to content

Commit

Permalink
TLDR-861 fixes after review
Browse files Browse the repository at this point in the history
  • Loading branch information
oksidgy committed Dec 20, 2024
1 parent 1a02c48 commit ee91759
Show file tree
Hide file tree
Showing 5 changed files with 31 additions and 42 deletions.
25 changes: 10 additions & 15 deletions dedoc/api/web/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -98,23 +98,9 @@ <h4>Attachments handling</h4>
</details>
</div>


<div class="parameters">
<h4>Tables handling </h4>
<details><summary>need_pdf_table_analysis</summary>
<br>
<p>
<label>
<input type="hidden" name="need_pdf_table_analysis" value="false">
<input type="checkbox" name="need_pdf_table_analysis" value="true" checked> need_pdf_table_analysis</label>
</p>
</details>
</div>


<div class="parameters">
<h4>PDF handling</h4>
<details><summary>pdf_with_text_layer, fast_textual_layer_detection, language, pages, is_one_column_document, document_orientation, need_header_footer_analysis, need_binarization, need_gost_frame_analysis</summary>
<details><summary>pdf_with_text_layer, need_pdf_table_analysis, fast_textual_layer_detection, language, pages, is_one_column_document, document_orientation, need_header_footer_analysis, need_binarization, need_gost_frame_analysis</summary>
<br>
<p>
<label>
Expand Down Expand Up @@ -145,6 +131,15 @@ <h4>PDF handling</h4>
</label>
</p>

<details><summary>need_pdf_table_analysis</summary>
<br>
<p>
<label>
<input type="hidden" name="need_pdf_table_analysis" value="false">
<input type="checkbox" name="need_pdf_table_analysis" value="true" checked> need_pdf_table_analysis</label>
</p>
</details>

<p>
<label>pages <input name="pages" type="text" size="8" value=":"></label>
</p>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -70,8 +70,8 @@ def __get_matrix_table_from_tree(self, table_tree: TableTree) -> ScanTable:
matrix.append(line)

# sorting column in each row
for i in range(0, len(matrix)):
matrix[i] = sorted(matrix[i], key=lambda cell: cell.bbox.x_top_left, reverse=False)
for i, row in enumerate(matrix):
matrix[i] = sorted(row, key=lambda cell: cell.bbox.x_top_left, reverse=False)

matrix_table = ScanTable(cells=matrix, bbox=table_tree.cell_box, page_number=self.page_number)

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -66,11 +66,10 @@ def clear_attributes(matrix_table: List[List[Cell]]) -> None:
cell.is_attribute = False
cell.is_attribute_required = False

def __is_indexable_column(self, matrix_table: List[List[Cell]], column_id: int, max_raw_of_search: int) -> bool:
def __is_indexable_column(self, matrix_table: List[List[Cell]], column_id: int, max_row_of_search: int) -> bool:
# № п/п
for i in range(max_raw_of_search + 1):
if column_id < len(matrix_table[i]) and "№" in matrix_table[i][column_id].get_text() and len(
matrix_table[i][column_id].get_text()) < len("№ п/п\n"):
for row in matrix_table[:max_row_of_search + 1]:
if column_id < len(row) and "№" in row[column_id].get_text() and len(row[column_id].get_text()) < len("№ п/п\n"):
return True
return False

Expand All @@ -83,22 +82,19 @@ def __set_attributes_for_type_top(self, cells: List[List[Cell]]) -> List[List[Ce
return cells

def __is_empty_column(self, matrix_table: List[List[Cell]], column_id: int) -> bool:
all_empty = True
for i in range(len(matrix_table)):
if len(matrix_table[i]) <= column_id:
break
if matrix_table[i][column_id].get_text() != "":
all_empty = False
break
return all_empty
for row in matrix_table:
if len(row) <= column_id:
return True
if row[column_id].get_text() != "":
return False
return True

def __is_empty_row(self, matrix_table: List[List[Cell]], row_index: int) -> bool:
all_empty = True
for j in range(len(matrix_table[row_index])):
if matrix_table[row_index][j].get_text() != "":
all_empty = False
break
return all_empty

for cell in matrix_table[row_index]:
if cell.get_text() != "":
return False
return True

def __analyze_attr_for_horizontal_union_raws(self, cells: List[List[Cell]]) -> List[int]:
horizontal_union_rows = []
Expand Down
3 changes: 1 addition & 2 deletions docs/source/dedoc_api_usage/api.rst
Original file line number Diff line number Diff line change
Expand Up @@ -150,7 +150,7 @@ Api parameters description
The encoded contents will be saved in the attachment's metadata in the ``base64_encode`` field.
Use ``true`` value to enable this behaviour.

* - :cspan:`3` **Tables handling**
* - :cspan:`3` **PDF handling**

* - need_pdf_table_analysis
- true, false
Expand All @@ -162,7 +162,6 @@ Api parameters description
If the document has a textual layer, it is recommended to use ``pdf_with_text_layer=tabby``,
in this case tables will be parsed much easier and faster.

* - :cspan:`3` **PDF handling**

* - pdf_with_text_layer
- true, false, tabby, auto, auto_tabby
Expand Down
9 changes: 4 additions & 5 deletions tests/api_tests/test_api_misc_multipage_table.py
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import os
import unittest
from typing import List

from tests.api_tests.abstract_api_test import AbstractTestApiDocReader
Expand Down Expand Up @@ -45,6 +46,7 @@ def test_api_ml_table_recognition_synthetic_data_1(self) -> None:
tables = self._get_tables(file_name, pdf_with_text_layer=pdf_param)
self.assertEqual(len(tables), 1)

@unittest.skip("TLDR-886 подправить координаты ячеек таблиц табби")
def test_api_ml_table_recognition_synthetic_data_3(self) -> None:
file_name = "example_mp_table_with_repeate_header_2.pdf"
for pdf_param in ["false", "true", "tabby"]:
Expand All @@ -65,8 +67,5 @@ def test_api_ml_table_recognition_synthetic_data_3(self) -> None:
self.assertListEqual(["Данные 3", "Данные 3", "Данные 3", "Данные 3", "Данные 3"], self._get_text_of_row(table[5]))
self.assertListEqual(["Данные 4", "Данные 4", "Данные 4", "Данные 4", "Данные 4"], self._get_text_of_row(table[6]))
self.assertListEqual(["Данные 5", "Данные 5", "Данные 5", "Данные 5", "Данные 5"], self._get_text_of_row(table[7]))
self.assertListEqual(["Заголовок\nБольшой", "Заголовок поменьше 1", "Заголовок поменьше 1", "Заголовок поменьше 2", "Заголовок поменьше 2"],
self._get_text_of_row(table[8]))
self.assertListEqual(["Заголовок\nБольшой", "Заголовочек 1", "Заголовочек 2", "Заголовочек 3", "Заголовочек 4"], self._get_text_of_row(table[9]))
self.assertListEqual(["Данные 6", "Данные 6", "Данные 6", "Данные 6", "Данные 6"], self._get_text_of_row(table[10]))
self.assertListEqual(["Данные 7", "Данные 7", "Данные 7", "Данные 7", "Данные 7"], self._get_text_of_row(table[11]))
self.assertListEqual(["Данные 6", "Данные 6", "Данные 6", "Данные 6", "Данные 6"], self._get_text_of_row(table[8]))
self.assertListEqual(["Данные 7", "Данные 7", "Данные 7", "Данные 7", "Данные 7"], self._get_text_of_row(table[9]))

0 comments on commit ee91759

Please sign in to comment.