Warning
As of January 2025, the Transactional Records Access Clearinghouse has left Syracuse University and its website has been taken offline, rendering this tool useless. If the website is put back up, or if a successor takes up TRAC's mantle, please file an issue on this repository and I'll update the tool to work with the new website.
This repository contains a tool for collating data published by the Transactional Records Access Clearinghouse (TRAC) in their immigration toolkit.
- selenium 4.17.0 (earlier might work but no guarantees)
- pandas 2.2.0 (earlier will probably work)
- tqdm
- Set up an environment with pandas and selenium (for conda instructions, see here).
- Download/locate the webdriver for your browser of choice - currently Firefox, Chrome, Edge and Safari are supported. Add the webdriver's path to your environment variables (in the case of Firefox, for additional instructions see here).
- Clone the repository, or just download
collate.py
. - Navigate to the TRAC webpage that you want to collate data from (to see if your tool is supported, check below). Note the URL and the names of the axes you want to collate.
collate.py
can be run from an IDE or the command line:
- To run in an IDE, open
collate.py
, navigate toSTANDALONE_PARAMS
, and set the following values:browser
: the name of the browser you downloaded that you downloaded the webdriver for.url
: the address of the TRAC webpage that you want to collate data from, including thehttps://
- for example,https://trac.syr.edu/phptools/immigration/mpp4/
.filename
: the name of the HDF file (including the.hdf
extension) you want the collated data to be saved in. Currently, only HDF file output is supported.axes
: the names of the three data axes you want to collate. In the final output dataest, values from the first two will be used as hierarchical indices, while values for the third will be used as columns. Support for more than three axes might be added later.
- To run from the command line, ensure that your conda environment is active and that
collate.py
is in your current directory. There are three ways to runcollate.py
from the command line:python collate.py
runs the script with the standalone parameters.python collate.py <options>
runs the script with options. The user will then be prompted for the arguments individually. Options are:--browser=<name>
: name of the browser to use. Valid names areFirefox
,Chrome
,Edge
, andSafari
.--headless
: use the browser in headless mode. (This option is not required.)-h
or--help
: show usage details. (This option is not required.)
python collate.py <options> <arguments>
runs the script with options and arguments. Arguments are:url
: full address of the TRAC webpagefile
: name or full path of the output file. Equivalent tofilename
inSTANDALONE_PARAMS
.axes
: Comma-separated list of the names of the axes of interest. Note that the list must be enclosed in "" if any names include spaces.
Note: even when collate.py
is used with supported TRAC tools, it is possible that it may occasionally throw StaleElementReferenceException
or NoSuchElementException
when the DOM changes unexpectedly or an element takes a while to load. The code has been structured to greatly limit such problems, but if you are still having trouble you can try the following:
- Try re-running on a faster internet connecection.
- Try re-running at a time when the TRAC servers are likely to have a low load (e.g., weekends, weekday evenings).
- Try re-arranging your names in the
axes
parameter so that the third axis is the one with the greatest number of values. This will decrease both execution time and the required number of interaction events (i.e., clicks and waits), so it will decrease the number of opportunities for an element to not load in properly.
Automated interaction with the following tools should be fully supported.
- New Proceedings Filed in Immigration Court
- Outcomes of Immigration Court Proceedings
- Asylum Filings
- Asylum Decisions
- MPP (Remain in Mexico) Deportation Proceedings—All Cases
- Unaccompanied Juveniles — Immigration Court Deportation Proceedings
- Priority Immigration Court Cases: Women with Children
- Border Patrol Arrests
- Stopping "Inadmissibles" at U.S. Ports of Entry
- Immigration and Customs Enforcement Arrests
- Latest Data: Immigration and Customs Enforcement Detainers
- Tracking Immigration and Customs Enforcement Detainers
- Latest Data: Immigration and Customs Enforcement Removals
- Historical Data: Immigration and Customs Enforcement Removals
- Removals under the Secure Communities Program
Automated interaction with the following tools is not supported. Some of these tools simply have an additional menu and are otherwise similar to the fully supported tools above, so you might have some success using collate.py
with them. Others have totally different interfaces, and will not work at all with collate.py
. Full support for these tools might be added later.
- Immigration Court Backlog - additional menu
- Pending Court Cases by Immigrant’s Address - different interface
- Judge-by-Judge Asylum Decisions in Immigration Courts - different interface
- Immigration Court Asylum Backlog - additional menu
- Immigration Court Bond Hearings and Related Case Decisions - different interface
- Immigration and Customs Enforcement Detention - additional menu
- Detention Facilities Average Daily Population - different interface
- Alternatives to Detention (ATD) - different interface
This repository is intended to make federal immigration data more accessible to students, researchers, and journalists. It is not affiliated with, supported by, or recognized by TRAC. Always make sure to cite your sources properly. If you use this tool, I would appreciate an acknowledgement, but no citation is necessary.