Let's research the landlord! New York City is in a housing crisis. Some landlords leave their buildings in despair and let their tenants suffer without heat in winter. Others evict their tenants, legally or illegally, in order to flip buildings and profit off of gentrification. Affordable housing is a scarce resource.
Residents, lawyers, tenants, and organizers who want to use data in their struggle turn to proprietary databases and resources, like PropertyShark, designed for real estate or contend with CSV and printouts from city websites. NYC-DB aims to give technologists and researchers who want to volunteer their time helping community groups who are defending the city against the real estate industry a leg up by providing a ready-to-use database filled with housing data.
NYC-DB builds a postgresql database containing the following datasets:
- Department of City Planning's Pluto: versions 15v1, 16v2, 17v1, 18v1, and 18v2
- DOB Job Filings
- DOB Complaints
- HPD Violations
- HPD Registrations
- HPD Complaints
- Department of Finance Rolling Sales
- Tax bills - Rent Stabilization Unit Counts (John Krauss's data)
- ACRIS
- 2017 Marshal Evictions
- ECB / Oath Hearings
- J-51 Exemptions
NYC-DB is a python3 command line program that downloads and loads datasets into postgres.
Just want a copy of the database?
Here are the latest versions available to download:
It's ~3gb compressed and ~20gb decompressed.
To decompress: bunzip2 nyc-db-2019-02-18.sql.bz2
Load the db: psql -d database-name -f nyc-db-2019-02-18.sql.bz2
To manage and create copies of the database yourself, you can see the nycdb command line tool available on pypi: pip3 install nycdb
see src/README.md
for more information on using the command line tool.
As a convenience you can create the database in one go using this command:
make nyc-db DB_HOST=localhost DB_DATABASE=nycdb DB_USER=databaseuser DB_PASSWORD=mypassword
You can also use Docker to both use and develop nycdb. This can be useful because you only need to install Docker--you don't need to worry about installing the proper version of Python, Postgres, or any other tools.
To proceed, first install Docker and then run:
docker-compose up
After Docker downloads and builds some things, it will start a Postgres server on port 7777 of your local machine, which you can connect to via a desktop client if you like. You can also press CTRL-C at any point to stop the server.
In a separate terminal, you can run:
docker-compose run app bash
At this point you are inside a bash shell in a container that has everything already
set up for you. The initial working directory will be /nycdb
, which is mapped to
the root of the project's repository. From here you can run nycdb
to access the
command-line tool.
To develop on nycdb itself:
- You can run
pytest
to run the test suite. - Any changes you make to the tool's source code will automatically be reflected
in future invocations of
nycdb
and/or the test suite. - If you don't have a desktop Postgres client, you can always run
nycdb --dbshell
to interactively inspect the database withpsql
.
You can leave the bash shell with exit
.
If you ever want to wipe the database, run docker-compose down -v
.
See the folder /ansible
for ansible playbooks to setup the database on a sever.
- Heatseek for ongoing support of the project and for their amazing work.
- @talos for his tax bill scrapping to get counts of rent-stabilization units
- census data
NYC-DB - Postgres database of NYC housing data
Copyright (C) 2016-2018 Ziggy Mintz
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.
The database files provided on this page are licensed CC BY-NC-SA 4.0.