Convert AWS Textract JSON to PRImA PAGE XML
This software converts OCR results from Amazon AWS Textract Response files to PRImA PAGE XML files.
In a Python virtualenv:
pip install textract2page
The package contains a file-based conversion function provided as CLI and Python API. (So this does not directly use the AWS API, which might be supported in the future.)
The function takes the Textract JSON file and the original image file which was used
as input for the OCR. (That is necessary because Textract stores coordinates in
float
ratios, whereas PAGE uses int
in pixel indices. However, if the with and height
of the image are passed as well, then the file is not needed – see below.)
Note: Only supports single-page requests. Multi-page JSON results must first be split up, for example via
jq '{Blocks: [.Blocks[] | select(.Page == 1)]}' aws.json > aws-page1.json jq '{Blocks: [.Blocks[] | select(.Page == 2)]}' aws.json > aws-page2.json jq '{Blocks: [.Blocks[] | select(.Page == 3)]}' aws.json > aws-page3.json
To convert a Textract file example.json
for an image file example.jpg
to a PAGE example.xml
:
from textract2page import convert_file
convert_file("example.json", "example.jpg", "example.xml")
Alternatively, if you do not have access to the image file, but do know its pixel resolution, use:
from textract2page import convert_file_without_image
convert_file_without_image("example.json",
# just give it a name (will not be read):
"example.jpg",
# set image width so PAGE coordinates will be correct:
2135,
# set image height so PAGE coordinates will be correct:
3240,
"example.xml")
Analogously, on the command line interface:
# with image file (path must be readable)
textract2page example.json example.jpg > example.xml
textract2page -O example.xml example.json example.jpg
# without image file (just keep path name)
textract2page --image-width 2135 --image-height 3240 example.json example.jpg > example.xml
textract2page --image-width 2135 --image-height 3240 -O example.xml example.json example.jpg
You can get a list of options with --help
or -h
Requires installation and a local copy of the repository.
To run regression tests with pytest
, do
make deps-test
make test-api
To run regression test via command line, do
# optionally:
sudo apt-get install xmlstarlet
make test-cli
(If xmlstarlet
is available, then the CLI test will
also validate the result tree. Otherwise, this just
checks the command completes without error.)