Skip to content

6a. Automatic processing with our Corpus Text Processor

Shelley Staples edited this page Sep 2, 2022 · 40 revisions

Contents


Getting started

The Corpus Text Processor (download here) for Windows or Mac is a downloadable application for Windows and Mac that provides batched (multiple-files-at-a-time) operations for common corpus processing tasks. The screenshot of the application below shows the four tasks currently available:

Screenshot of application UI

After running operations on a set of files, Corpus Text Processor provides debugging output that indicates how many files were processed and which files, if any, had issues.

Installation

Download the latest version of the Corpus Text Processor for Windows or MacOS at https://github.com/writecrow/corpus_text_processor/releases

Trouble installing?

If you get error messages related to application security upon installation, please review one of these pages based on your operating system:

Preparing files to be processed

Before running the tool, place all files to be processed in a specific folder; this can include sub-directories. It is recommended that you then create a new top-level folder to save your processed files to. You can create that folder at the same level of the top-level parent directory for the files you wish to process. You don’t need to recreate the sub-directory structure because the corpus processing tool will do this for you.

You may have files in a variety of formats in the "Original" folder, such as .doc, .pdf, etc. These files, however, need to be named differently. If multiple files in different formats have the same name, they will be written over each other after being converted to .txt format. In this case, you will get only one .txt file in the "Converted" folder.

Processing a folder of files

To run the tool, choose the folder that you want to process (below, “Original”) and your output folder to save the processed data to (below, “Converted”). You can only process a folder, not individual files. If you have multiple sub-directories to convert, just choose the parent directory. The corpus processing tool will process all the sub-directories and recreate the directory structure in the output folder. DO NOT select the same folder to read and write the files.

We recommend running the processes in the order sequentially (Convert to plaintext, Encode to UTF-8 encoding, Standardize non-ASCII characters and remove non-English characters, Remove PDF metadata). In fact, it should be noted that the "Standardize non-ASCII characters and remove non-English characters" process is designed only to work with files already in UTF-8 format. The only exception to this is that you do not generally need to run the “Remove PDF metadata” process. We use this for de-identifying files that will go into the repository as PDFs as well as plain text.

Reviewing the results

Once the files have been processed (after each processing step), inspect documents to ensure proper conversion:

  1. Check for errors in the program’s debug window.

  2. Determine whether you have the same number of input and output files:

    a. If you open a folder in Windows File Explorer you can see the number of files in the bottom left corner.

Screenshot of Windows text number

b. For Macs, right click and choose “Get Info” to get the number of files.

Screenshot of Mac text number

  1. Check if there are any files that haven’t been processed correctly. Look for files of size 0 bytes or 1 byte. Change your view to list view in order to see the file sizes of all the files in a folder.

  2. For any files that have failed to process, troubleshoot a couple of items:

    1. Is it read only? If so, try opening and saving the input file in Word before running the program again.
    2. Is the file name too long? Try renaming the file, retaining important information in the filename (e.g., name or group number).
    3. Are there special characters in the file name? If a file doesn’t convert, check for special characters in the file name: colons and other symbols, other language characters, etc. Remove these from the file name and try again.

Advantages of our Corpus Text Processor

  • All three steps are in one package. Other programs are available that do one of these steps but the Corpus Text Processor allows you to do all three steps with one program.
  • Like some (but not all) other programs, the Corpus Text Processor attempts to alleviate some of the problems with converting PDFs by first converting the PDFs to Word.
  • We have also added logic to remove extra line breaks in cases where we are able to reliably remove them.
  • The corpus text processor recreates the folder structure (and copies into a new location).
  • Our team is actively using our tool, meaning that we are updating it as we encounter issues with our own corpus building.

Known limitations

  • Text-as-image PDFs are not currently supported for conversion to plaintext. We are in alpha development for a script that uses the Textract OCR library for converting text-as-image PDFs. You are free to use that project, as-is, at https://github.com/writecrow/ocr2text
  • The tool can detect and convert all of the encoding types listed on the Chardet library page. The tool will make a best-effort attempt to convert other encoding types but is not guaranteed to work.
  • Text files that consist primarily of non-Romanized characters may interfere with the tool's ability to identify the encoding type and may not convert.
  • Converting files of type .doc to plaintext is not currently supported. We recommend using a batch utility to convert .doc files to .docx format, which this application can convert. Here are recommended utilities for converting .doc files:
  • Currently the program only works with English. We have plans for developing a tool that will work with Portuguese and Russian in the future.

Video presentation

A video version of this content is available on our YouTube channel.

Video: Corpus Text Processor Demonstration

Navigating CIABATTA

Previous: 6. Converting, encoding, and standardizing your data

Next: 6b. Manually converting your data