Metadata-Version: 2.1
Name: hudpy
Version: 0.2.0
Summary: A python interface to the US Department of Housing and Urban Development APIs.
Home-page: https://github.com/etam4260/hudpy
Author: Emmet Tam
Author-email: emmet_tam@yahoo.com
License: UNKNOWN
Project-URL: Bug Tracker, https://github.com/etam4260/hudpy/issues
Platform: UNKNOWN
Classifier: Programming Language :: Python :: 3
Classifier: License :: OSI Approved :: GNU General Public License v2 (GPLv2)
Classifier: Operating System :: OS Independent
Requires-Python: >= 2.6
Description-Content-Type: text/markdown
Requires-Dist: pandas
Requires-Dist: datetime
Requires-Dist: typing
Requires-Dist: urllib3

# hudpy <img src='logo.png' align="right" width="139"/>


<!-- badges: start -->

[![ Project Status: Active – The project has reached a stable, usable state and is being actively developed.](https://www.repostatus.org/badges/latest/active.svg)](https://www.repostatus.org/#active)
[![PyPI Latest Release](https://img.shields.io/pypi/v/hudpy.svg)](https://pypi.org/project/hudpy/)
[![License](https://img.shields.io/pypi/l/hudpy.svg)](https://raw.githubusercontent.com/etam4260/hudpy/blob/main/LICENSE)
[![Downloads](https://static.pepy.tech/personalized-badge/hudpy?period=month&units=international_system&left_color=black&right_color=orange&left_text=PyPI%20downloads%20per%20month)](https://pepy.tech/project/hudpy)
[![Codecov test coverage](https://codecov.io/gh/etam4260/hudpy/branch/main/graph/badge.svg)](https://app.codecov.io/gh/etam4260/hudpy?branch=main)
[![CodeFactor](https://www.codefactor.io/repository/github/etam4260/hudpy/badge)](https://www.codefactor.io/repository/github/etam4260/hudpy)

<br/><br/> 
[![devel version](https://img.shields.io/badge/devel%20version-0.2.0-yellow)]()

<!-- badges: end -->

Are you a R developer? Check out [rhud](https://github.com/etam4260/rhud) instead

## Installation

To install from pypi use

```
pip install hudpy
```

You can install the development version by cloning the repository

```
git clone https://github.com/etam4260/hudpy.git
```

now run

```
pip install ./hudpy
```


## Key Access

To use functions provided by this package, you need to get access HUD
USER via token. Go to <https://www.huduser.gov/hudapi/public/login> to
register for an account and then create a token with access to all
datasets provided by HUD. This will include selecting USPS Crosswalk,
Fair Markets Rent, Income Limits, and Comprehensive Housing
Affordability Strategy.

Now copy and paste that key into the hud_set_key() function.

``` 
hud_set_key("sample-key")
```

## Simplistic Example

This sample provided below shows how to query the USPS Crosswalk API

``` 
hud_cw_zip_tract(zip = '35213', year = ['2010'], quarter = ['1'])
```

## Housing and Urban Development in Python

-   This interface uses the HUD User Data API but is not endorsed or
    certified by HUD User.

The goal of this project is to provide an easy-to-use interface to
access various open-source APIs provided by the U.S Housing and Urban
Development. These include the USPS Crosswalk Files, Fair Markets Rent,
Income Limits, and Comprehensive Housing and Affordability Strategy.
Although HUD does provide datasets for other programs, they are
currently not supported by an API.

Please read
<https://www.huduser.gov/portal/dataset/api-terms-of-service.html> for
all terms of service.

According to HUD USER:

All services, which utilize or access the API, should display the
following notice prominently within the application: “This product uses
the HUD User Data API but is not endorsed or certified by HUD User.” You
may use the HUD User name in order to identify the source of API content
subject to these rules. You may not use the HUD User name, or the like
to imply endorsement of any product, service, or entity, not-for-profit,
commercial or otherwise.

## HUD User: <https://www.huduser.gov/portal/datasets>

According to (HUD User Home Page \| HUD USER), HUD User is a U.S.
Department of Housing and Urban Development information source that
includes reports and reference documents. HUD USER was founded in 1978
by the Department of Housing and Urban Development’s Office of Policy
Development and Research.

HUD User maintains an API to gain access to their data. However, their
API system can be confusing and provides their information in JSON
format rather than a data-frame like object. Although there exist file
downloadables, R users may want to be able to extract specific bits of
the data into memory.

## Citation

Please cite this package using:

Tam E, Reilly A, Ghaedi H, Jin S (2022). hudpy: A Python Interface to the
HUD (US Department of Housing and Urban Development) APIs. 0.1.0.9000,  
<https://github.com/etam4260/hudpy/>.

## Available Data

The APIs and datasets which this library interfaces are listed below.
The HUD also provide miscellaneous supplemental APIs under them.

1.  HUD User

-   USPS Crosswalk
    (<https://www.huduser.gov/portal/dataset/uspszip-api.html>)

| USPS Crosswalk Files     | Years           |
|--------------------------|-----------------|
| `hud_cw_zip_tract()`     | 2010-2021       |
| `hud_cw_zip_county()`    | 2010-2021       |
| `hud_cw_zip_cbsa()`      | 2010-2021       |
| `hud_cw_zip_cbsadiv()`   | <b>2017-2021<b> |
| `hud_cw_zip_countysub()` | <b>2018-2021<b> |
| `hud_cw_zip_cd()`        | 2010-2021       |
| `hud_cw_tract_zip()`     | 2010-2021       |
| `hud_cw_county_zip()`    | 2010-2021       |
| `hud_cw_cbsa_zip()`      | 2010-2021       |
| `hud_cw_cbsadiv_zip()`   | <b>2017-2021<b> |
| `hud_cw_cd_zip()`        | 2010-2021       |
| `hud_cw_countysub_zip()` | <b>2018-2021<b> |
| `hud_cw()`               | 2010-2021       |
| `crosswalk()`            | 2010-2021       |
|                          |                 |
| `z_in_trt()`             | 2010-2021       |
| `z_in_cty()`             | 2010-2021       |
| `z_in_cbsa()`            | 2010-2021       |
| `z_in_cbsadiv()`         | <b>2017-2021<b> |
| `z_in_ctysb()`           | <b>2018-2021<b> |
| `z_in_cd()`              | 2010-2021       |
| `trt_in_z()`             | 2010-2021       |
| `cty_in_z()`             | 2010-2021       |
| `cbsa_in_z()`            | 2010-2021       |
| `cbsadiv_in_z()`         | <b>2017-2021<b> |
| `ctysb_in_z()`           | <b>2018-2021<b> |
| `cd_in_z()`              | 2010-2021       |


-   Fair Markets Rent
    (<https://www.huduser.gov/portal/dataset/fmr-api.html>)
    -   Small Areas Fair Markets Rent

| Fair Markets Rent            | Years     |
|------------------------------|-----------|
| `hud_fmr_state_counties()`   | 2017-2022 |
| `hud_fmr_state_metroareas()` | 2017-2022 |
| `hud_fmr_county_zip()`       | 2017-2022 |
| `hud_fmr_metroarea_zip()`    | 2017-2022 |
| `hud_fmr()`                  | 2017-2022 |

-   Income Limits
    (<https://www.huduser.gov/portal/dataset/fmr-api.html>)

| Income Limits | Years     |
|---------------|-----------|
| `hud_il()`    | 2017-2022 |

-   Comprehensive Housing and Affordability Strategy
    (<https://www.huduser.gov/portal/dataset/chas-api.html>)

| Comprehensive Housing and Affordability Strategy | Years                                                                                              |
|--------------------------------------------------|----------------------------------------------------------------------------------------------------|
| `hud_chas_nation()`                              | 2014-2018 , 2013-2017, 2012-2016, 2011-2015, 2010-2014, 2009-2013, 2008-2012, 2007-2011, 2006-2010 |
| `hud_chas_state()`                               | 2014-2018 , 2013-2017, 2012-2016, 2011-2015, 2010-2014, 2009-2013, 2008-2012, 2007-2011, 2006-2010 |
| `hud_chas_county()`                              | 2014-2018 , 2013-2017, 2012-2016, 2011-2015, 2010-2014, 2009-2013, 2008-2012, 2007-2011, 2006-2010 |
| `hud_chas_state_mcd()`                           | 2014-2018 , 2013-2017, 2012-2016, 2011-2015, 2010-2014, 2009-2013, 2008-2012, 2007-2011, 2006-2010 |
| `hud_chas_state_place()`                         | 2014-2018 , 2013-2017, 2012-2016, 2011-2015, 2010-2014, 2009-2013, 2008-2012, 2007-2011, 2006-2010 |
| `hud_chas()`                                     | 2014-2018 , 2013-2017, 2012-2016, 2011-2015, 2010-2014, 2009-2013, 2008-2012, 2007-2011, 2006-2010 |

-   US Geographic Entities

| US Geographies                      |
|-------------------------------------|
| `hud_nation_states_territories()`   |
| `hud_state_metropolitan()`          |
| `hud_state_counties()`              |
| `hud_state_places()`                |
| `hud_state_minor_civil_divisions()` |

-   Key access

| Management             |
|------------------------|
| `hud_set_key()`        |
| `hud_get_key()`        |
| `hud_set_user_agent()` |
| `hud_get_user_agent()` |

-   Caching

| Caching               |
|-----------------------|
| `hud_set_cache_dir()` |
| `hud_get_cache_dir()` |
| `hud_clear_cache()`   |

-   Utilities

| Utilities          |
|--------------------|
| `rhud_website()`   |
| `hud_rec_cw_yr()`  |
| `hud_rec_fmr_yr()` |
| `hud_rec_il_yr()`  |

## Contributors

-   Emmet Tam(<https://github.com/etam4260>)\[<emmet_tam@yahoo.com>\]
-   Allison Reilly()\[<areilly2@umd.edu>\]
-   Hamed Ghaedi()\[<hghaedi@terpmail.umd.edu>\]
-   Shuyu Jin(<https://github.com/geojsy>)\[<geojsy@umd.edu>\]

## Disclaimers

-   License: GPL >= 2

-   This interface uses the HUD User Data API but is not endorsed or
    certified by HUD User.

-   The limit on the maximum number of API calls is 1200 queries a min.
    Each function call does not correspond to a single API call!

-   This is a WIP so please report any issues or bugs to:
    <https://github.com/etam4260/hudpy/issues>

-   This is open source, so please fork and introduce some pull
    requests!

## References

HUD User Home Page: HUD USER. HUD User Home Page \| HUD USER. (n.d.).
Retrieved February 24, 2022, from <https://www.huduser.gov/portal/home.html>


