Skip to content

a-mahr/quipucamayoc

 
 

Repository files navigation

Quipucamayoc: tools for digitizing historical data

This is an incomplete version, forked from the complete version, to make specific changes. is a Python package that simplifies the extraction of historical data from scanned images and PDFs. It's designed to be modular and so it can be used together with other existing tools, and can be extended easily by users.

For an overview of how to use quipucamayoc to digitize historical data, see the original quipucamayoc repository, here

Version Notes

To use this version, you must follow the installation notes for git below. This version is not available through pypi. This version has several added features under development. Notably,

  • output can now be specified with -o to output a csv file, in addition to a tsv as default.
  • Output can also be turned to a single file using --page-append N, rather than to a file per table found. For files with multi-page tables (especially where all tables in the file have the same construction), this is remarkably useful. For example, if the each header takes up 2 rows, then --page-append 2 will keep the first table intact, and append each following table with the first 2 rows removed.
  • Timeouts are now fully caught, where previously upon timeout it could simply pass as though it had succeeded
  • Directory now works when used with -d "dir" --extension pdf. All files are sent to AWS, then all files are waited on, which ideally means that wait times get shorter for each returned file.
  • Output directory can now be specified with --output-dir. If none is specified, files go to a directory nested in the same directory as the file, and directories go to a directory in the same directory as the directory.

Installation

Note that quipucamayoc has been tested against Python 3.10 and newer versions, but should also work with Python 3.9.

Git Install

After cloning the repo to your computer and navigating to the quipucamayoc folder, run:

  • pip install . to install the package locally
  • pip install -e . to install locally with a symlink so changes are automatically updated (recommended for developers)

After installation

AWS

AWS configuration is quite cumbersome, so it has been automated. To do so, follow these four steps:

  1. Download and install the aws command line interface (CLI). Update: quipucamayoc installs the awscli package so this step might not be necessary anymore.
  2. Configure your credentials with aws configure. This requires an Amazon/AWS account.
  3. From the command line, run the quipucamayoc command quipu aws install

Notes:

  • You can avoid step 1 by directly [writing your credentials[(https://docs.aws.amazon.com/cli/latest/userguide/cli-configure-files.html)] to the credentials file.
  • Steps 3-4 are also available from within Python in the setup_textract() and test_textract() functions.
  • If you want to remove all quipucamayoc artifacts from your AWS account, you can run quipu aws uninstall from the command line.
  • The default AWS region is aws-east-1. To use other regions, use the --region <name> option.

Usage

  • From the command line, you can extract tables using AWS via quipu extract-tables --filename <myfile.pdf>

TODO

  • Automatically set up Textract pipeline
  • Expose key functions as command line tools
  • Allow parallel (async?) tasks. Useful for OpenCV (CPU-intensive) and Textract calls (IO-intensive). Consider also uvloop
  • Include Poppler by default on Windows
  • Add mypy/(flake8|black)

Contributing

Feel free to submit push requests. For consistency, code should comply with pep8 (as long as its reasonable), and with the style guides by @kennethreitz and google. Read more here.

Citation

(Download BibTex file here)

As text

  • Sergio Correia, Stephan Luck: “Digitizing Historical Balance Sheet Data: A Practitioner's Guide”, 2022; arXiv:2204.00052.

As BibTex

@misc{quipucamayoc,
  Author = {Correia, Sergio and Luck, Stephan},
  Title = {Digitizing Historical Balance Sheet Data: A Practitioner's Guide},
  Year = {2022},
  eprint = {arXiv:2204.00052},
  journal={arXiv preprint arXiv:2204.00052}
}

Acknowledgments

Quipucamayoc is built upon the work and improvements of many users and developers, from which it was heavily inspired, such as:

It is also relies for most of its work on the following open source projects:

License

Quipucamayoc is developed under the GNU Affero GPL v3 license.

Why "quipucamayoc"?

The quipucamayocs were the Inca empire officials in charge of desciphering (amonst other things) accounting information stored in quipus. Our goal for this package is to act as a sort of quipucamayoc, helping researchers in desciphering and extracting historical information, particularly balance sheets and numerical records.

About

dev repo for article

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 99.6%
  • TeX 0.4%