Skip to main content

Python client with tools for working with recreation.gov data.

Project description

pyFedCamp

This package works with data from the recreation.gov system for camping reservations on U.S. Federal lands. It makes up for a number of things not covered in "The Hub" (the system used for managing reservations and campground operations).

Input Parameters

The following are required input parameters for the Reservations class:

  • input_file (str) - The relative or absolute path to the Camping Reservation Detail Report input file that will be processed
  • create_placards (bool) - True to run the build_placards function and generate the downloadable PDF file
  • placards_filename (str) - Defaults to 'placards.pdf'
  • fed_unit (str) - The display name for the U.S. Federal land unit that will be examined and processed
  • campground (str) - The display name for the specific campground on the Federal land unit
  • arrival_dates (list of dates) - One or more arrival dates (date objects) that must be found in the input file for placards; defaults to today's date
  • campsites (list of strings) - Optional list of campsites to filter on from the input data when only certain sites need to be printed or reported on

Generated DataFrames

The Reservations class produces several intermediate and summary DataFrames during processing:

  • res_df: The main DataFrame containing all reservation records loaded from the input spreadsheet, with additional columns for reporting and filtering.
  • occupied_reservations: Filtered reservations that are currently reserved, checked in, or checked out.
  • occupied_overnights: Expanded DataFrame with one row per occupied night per reservation, including date, occupants, and site footprint.
  • first_nights: Subset of occupied_overnights for the first night of multi-night reservations.
  • single_nights: Subset of occupied_overnights for single-night reservations.
  • sites_per_night: Summary of the number of occupied sites per night, grouped by date and site type.
  • occupants_per_night: Summary of the number of occupants per night, grouped by date and site type.
  • weekly_occupants: Weekly summary of occupants, including single-night, first-night, and total occupants, grouped by year, week, and day.
  • busiest_days: For each week, the day with the highest weighted occupancy.
  • placards_df: Filtered DataFrame containing only the reservations for which placards will be generated.

These DataFrames are available as attributes of the Reservations instance after running the relevant methods.

Placards

The seminal use case for pyFedCamp was the production of custom placards to be printed out and placed on sign posts for each campsite on the day/night of initial reservation. We found ourselves tweaking the existing placard print-out from rec.gov to make things larger so that members of staff and guests could read them at a distance. All of the data necessary to produce the placards is contained in the Camping Reservation Detail report, including the obfuscated (non-PII) customer initials, arrival/departure date, and other information.

The Reservations class handles reading the Excel file produced in the Camping Reservation Detail Report, ensuring that the file is in the expected format (more on this in the dependencies section), and builds a dataframe from the actual data part of the worksheet (minus multiple header rows). The build_placards function uses the Python ReportLab package to produce an 8.5x11 PDF with up to 4 placards per sheet, similar to the built-in rec.gov report.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyfedcamp-0.0.5.tar.gz (235.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pyfedcamp-0.0.5-py3-none-any.whl (234.6 kB view details)

Uploaded Python 3

File details

Details for the file pyfedcamp-0.0.5.tar.gz.

File metadata

  • Download URL: pyfedcamp-0.0.5.tar.gz
  • Upload date:
  • Size: 235.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.0 CPython/3.10.9 Darwin/24.5.0

File hashes

Hashes for pyfedcamp-0.0.5.tar.gz
Algorithm Hash digest
SHA256 462071f07f05e78826a8b231dfd499f618093675a92a103009711f2f6d6f3f68
MD5 6fda7f527823641fd214354c04effe52
BLAKE2b-256 bdd78fb2cafd21ee6387087a298930067db95c65c728ec81890b424ab9a16928

See more details on using hashes here.

File details

Details for the file pyfedcamp-0.0.5-py3-none-any.whl.

File metadata

  • Download URL: pyfedcamp-0.0.5-py3-none-any.whl
  • Upload date:
  • Size: 234.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.0 CPython/3.10.9 Darwin/24.5.0

File hashes

Hashes for pyfedcamp-0.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 860d73a514ea8085d34075f64ea84d050921b9c336a7c64e31db2fa635633ff9
MD5 be9a13c10b7ea381c3bdd8180defe1aa
BLAKE2b-256 8c270c856d2c13289bff538e804657373fa85781022df66f3836b99d86fb0220

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page