From be8aae646e5205504845e555efef82f8f15c0af0 Mon Sep 17 00:00:00 2001 From: Ravi Makhija Date: Sun, 15 Oct 2023 11:45:45 -0400 Subject: [PATCH 1/3] Add data dictionary for LIHTCPUB.CSV --- .../LIHTC Data Dictionary 2021.pdf | Bin 0 -> 43610 bytes 1 file changed, 0 insertions(+), 0 deletions(-) create mode 100644 workstream2/data_dictionaries/LIHTC Data Dictionary 2021.pdf diff --git a/workstream2/data_dictionaries/LIHTC Data Dictionary 2021.pdf b/workstream2/data_dictionaries/LIHTC Data Dictionary 2021.pdf new file mode 100644 index 0000000000000000000000000000000000000000..8e72908330f0c560a571c5681c4e3de1b00f9476 GIT binary patch literal 43610 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 Date: Sun, 15 Oct 2023 11:56:55 -0400 Subject: [PATCH 2/3] Update variables in app.py and form.html --- workstream1/app.py | 52 ++++++++++++++++----------------- workstream1/templates/form.html | 9 ++---- 2 files changed, 28 insertions(+), 33 deletions(-) diff --git a/workstream1/app.py b/workstream1/app.py index 5b48a9d..1fdfa50 100644 --- a/workstream1/app.py +++ b/workstream1/app.py @@ -1,5 +1,4 @@ from flask import Flask, request, render_template -import json import mariadb app = Flask(__name__) @@ -20,31 +19,31 @@ def index(): form_data = request.form portfolio_data = ( - form_data['portfolioID'], - form_data['portfolioName'], - form_data['portfolioYear'] + form_data['PortfolioID'], + form_data['PortfolioName'], + form_data['PortfolioYear'] ) project_data = ( - form_data['portfolioID'], - form_data['projectName'], - form_data['address'], - form_data['censusTract'], - form_data.get('areaOfEconomicDistress', 'N'), - form_data['totalProjectCost'] + form_data['PortfolioID'], + form_data['txtPPN'], + form_data['txtStreet'], + form_data['txtCity'], + form_data['txtState'], + form_data['txtZIP'] ) metrics_data = [ - (1, form_data['unitsBelow30AMI'], form_data['projectName']), - (2, form_data['unitsBelow50AMI'], form_data['projectName']), - (3, form_data['unitsBelow60AMI'], form_data['projectName']), - (4, form_data['unitsBelow80AMI'], form_data['projectName']), - (5, form_data['unitsBelow120AMI'], form_data['projectName']), - (6, form_data['unitsAbove120AMI'], form_data['projectName']), - (7, form_data['totalNumberOfUnits'], form_data['projectName']), - (8, form_data['totalPrivateSources'], form_data['projectName']), - (9, form_data['totalPublicSources'], form_data['projectName']), - (10, form_data['cmfLoanAmount'], form_data['projectName']) + (1, form_data['txtUnder30'], form_data['projectName']), + (2, form_data['txtUnder50'], form_data['projectName']), + (3, form_data['txtUnder60'], form_data['projectName']), + (4, form_data['txtUnder80'], form_data['projectName']), + (5, form_data['txtUnder120'], form_data['projectName']), + (6, form_data['txtAbove120'], form_data['projectName']), + (7, form_data['txtNoCmfClf'], form_data['projectName']), + (8, form_data['txtPrivCash'], form_data['projectName']), + (9, form_data['txtGovCash'], form_data['projectName']), + (10, form_data['txtCMFLoan'], form_data['projectName']), ] # Connect to MariaDB @@ -58,17 +57,17 @@ def index(): cur.execute("INSERT INTO Portfolios(PortfolioID, PortfolioName, PortfolioYear) VALUES (%s, %s, %s)", portfolio_data) # Insert the new project - cur.execute("INSERT INTO Projects(PortfolioID, ProjectName, Address, CensusTract, AreaOfEconomicDistress, TotalProjectCost) VALUES (%s, %s, %s, %s, %s, %s)", project_data) + cur.execute("INSERT INTO Projects(PortfolioID, txtPPN, txtAddr1, txtAddr2, txtCity, txtState, txtZIP) VALUES (%s, %s, %s, %s, %s, %s, %s)", project_data) for metric in metrics_data: - cur.execute("INSERT INTO ProjectMetrics(MetricID, MetricValue, ProjectName) VALUES (%s, %s, %s)", metric) + cur.execute("INSERT INTO ProjectMetrics(MetricID, MetricValue, txtPPN) VALUES (%s, %s, %s)", metric) # 1. Check for 45% Very Low Income Families cur.execute(""" SELECT (SUM(CASE WHEN MetricID = 1 THEN MetricValue ELSE 0 END) + SUM(CASE WHEN MetricID = 2 THEN MetricValue ELSE 0 END)) / - SUM(CASE WHEN MetricID = 7 THEN MetricValue ELSE 0 END) * 100 AS PercentageForVeryLowIncome + SUM(CASE WHEN MetricID IN (1, 2, 3, 4, 5, 6) THEN MetricValue ELSE 0 END) * 100 AS PercentageForVeryLowIncome FROM ProjectMetrics; """) result = cur.fetchone() @@ -91,7 +90,7 @@ def index(): SUM(CASE WHEN AreaOfEconomicDistress = 'Y' THEN TotalProjectCost ELSE 0 END) / SUM(TotalProjectCost) * 100 AS PercentageInEconomicDistress FROM Projects - JOIN ProjectMetrics ON Projects.ProjectName = ProjectMetrics.ProjectName AND ProjectMetrics.MetricID = 7; + JOIN ProjectMetrics ON Projects.txtPPN = ProjectMetrics.txtPPN AND ProjectMetrics.MetricID = 7; """) result = cur.fetchone() if result[0] < 60: @@ -100,11 +99,11 @@ def index(): # 4. Check for each project having 20% for Low Income Families cur.execute(""" SELECT - ProjectName, + txtPPN, (SUM(CASE WHEN MetricID IN (1,2,3,4) THEN MetricValue ELSE 0 END) / SUM(CASE WHEN MetricID = 7 THEN MetricValue ELSE 0 END)) * 100 AS PercentageForLowIncome FROM ProjectMetrics - GROUP BY ProjectName; + GROUP BY txtPPN; """) projects = cur.fetchall() for project in projects: @@ -120,3 +119,4 @@ def index(): if __name__ == '__main__': app.run(debug=True) + diff --git a/workstream1/templates/form.html b/workstream1/templates/form.html index 29c0052..9c48509 100644 --- a/workstream1/templates/form.html +++ b/workstream1/templates/form.html @@ -102,13 +102,8 @@

Project Details:

- -
-
- -
- -
+ +
From bc5028ca75eafdd61b10fc3a834ad16a7c30ba9a Mon Sep 17 00:00:00 2001 From: Antonio Migotto Date: Sun, 15 Oct 2023 12:06:44 -0400 Subject: [PATCH 3/3] Update app.py queries --- workstream1/app.py | 129 +++++++++++++++++++++++++-------------------- 1 file changed, 73 insertions(+), 56 deletions(-) diff --git a/workstream1/app.py b/workstream1/app.py index 1fdfa50..e92a233 100644 --- a/workstream1/app.py +++ b/workstream1/app.py @@ -6,44 +6,45 @@ # Configuration used to connect to MariaDB config = { - 'host': '127.0.0.1', - 'port': 3306, - 'user': 'root', - 'password': 'new_password', - 'database': 'CMFPortfolio' + "host": "127.0.0.1", + "port": 3306, + "user": "root", + "password": "new_password", + "database": "CMFPortfolio", } -@app.route('/', methods=['GET', 'POST']) + +@app.route("/", methods=["GET", "POST"]) def index(): - if request.method == 'POST': + if request.method == "POST": form_data = request.form portfolio_data = ( - form_data['PortfolioID'], - form_data['PortfolioName'], - form_data['PortfolioYear'] + form_data["PortfolioID"], + form_data["PortfolioName"], + form_data["PortfolioYear"], ) project_data = ( - form_data['PortfolioID'], - form_data['txtPPN'], - form_data['txtStreet'], - form_data['txtCity'], - form_data['txtState'], - form_data['txtZIP'] + form_data["PortfolioID"], + form_data["txtPPN"], + form_data["txtStreet"], + form_data["txtCity"], + form_data["txtState"], + form_data["txtZIP"], ) metrics_data = [ - (1, form_data['txtUnder30'], form_data['projectName']), - (2, form_data['txtUnder50'], form_data['projectName']), - (3, form_data['txtUnder60'], form_data['projectName']), - (4, form_data['txtUnder80'], form_data['projectName']), - (5, form_data['txtUnder120'], form_data['projectName']), - (6, form_data['txtAbove120'], form_data['projectName']), - (7, form_data['txtNoCmfClf'], form_data['projectName']), - (8, form_data['txtPrivCash'], form_data['projectName']), - (9, form_data['txtGovCash'], form_data['projectName']), - (10, form_data['txtCMFLoan'], form_data['projectName']), + (1, form_data["txtUnder30"], form_data["projectName"]), + (2, form_data["txtUnder50"], form_data["projectName"]), + (3, form_data["txtUnder60"], form_data["projectName"]), + (4, form_data["txtUnder80"], form_data["projectName"]), + (5, form_data["txtUnder120"], form_data["projectName"]), + (6, form_data["txtAbove120"], form_data["projectName"]), + (7, form_data["txtNoCmfClf"], form_data["projectName"]), + (8, form_data["txtPrivCash"], form_data["projectName"]), + (9, form_data["txtGovCash"], form_data["projectName"]), + (10, form_data["txtCMFLoan"], form_data["projectName"]), ] # Connect to MariaDB @@ -51,72 +52,88 @@ def index(): cur = conn.cursor() # Check if portfolio already exists - cur.execute("SELECT * FROM Portfolios WHERE PortfolioID = %s", (portfolio_data[0],)) + cur.execute( + "SELECT * FROM Portfolios WHERE PortfolioID = %s", (portfolio_data[0],) + ) if cur.fetchone() is None: # Insert new portfolio if it doesn't exist - cur.execute("INSERT INTO Portfolios(PortfolioID, PortfolioName, PortfolioYear) VALUES (%s, %s, %s)", portfolio_data) + cur.execute( + "INSERT INTO Portfolios(PortfolioID, PortfolioName, PortfolioYear) VALUES (%s, %s, %s)", + portfolio_data, + ) # Insert the new project - cur.execute("INSERT INTO Projects(PortfolioID, txtPPN, txtAddr1, txtAddr2, txtCity, txtState, txtZIP) VALUES (%s, %s, %s, %s, %s, %s, %s)", project_data) - + cur.execute( + "INSERT INTO Projects(PortfolioID, txtPPN, txtAddr1, txtAddr2, txtCity, txtState, txtZIP) VALUES (%s, %s, %s, %s, %s, %s, %s)", + project_data, + ) + for metric in metrics_data: - cur.execute("INSERT INTO ProjectMetrics(MetricID, MetricValue, txtPPN) VALUES (%s, %s, %s)", metric) + cur.execute( + "INSERT INTO ProjectMetrics(MetricID, MetricValue, txtPPN) VALUES (%s, %s, %s)", + metric, + ) # 1. Check for 45% Very Low Income Families - cur.execute(""" + cur.execute( + """ SELECT (SUM(CASE WHEN MetricID = 1 THEN MetricValue ELSE 0 END) + SUM(CASE WHEN MetricID = 2 THEN MetricValue ELSE 0 END)) / SUM(CASE WHEN MetricID IN (1, 2, 3, 4, 5, 6) THEN MetricValue ELSE 0 END) * 100 AS PercentageForVeryLowIncome FROM ProjectMetrics; - """) + """ + ) result = cur.fetchone() if result[0] < 45: - print("Failed Requirement: Less than 45% of rental affordable housing units for Very Low Income Families.") + print( + "Failed Requirement: Less than 45% of rental affordable housing units for Very Low Income Families." + ) # 2. Check for total project cost being 10x the CMF award - cur.execute(""" + cur.execute( + """ SELECT - SUM(TotalProjectCost) / (SELECT 10 * SUM(CASE WHEN MetricID = 10 THEN MetricValue ELSE 0 END) FROM ProjectMetrics) AS CostToCMFRatio - FROM Projects; - """) + (SUM(CASE WHEN MetricID = 7 THEN MetricValue ELSE 0 END) + + SUM(CASE WHEN MetricID = 8 THEN MetricValue ELSE 0 END) + + SUM(CASE WHEN MetricID = 9 THEN MetricValue ELSE 0 END)) + / (10 * SUM(CASE WHEN MetricID = 10 THEN MetricValue ELSE 0 END)) AS CostToCMFRatio + FROM ProjectMetrics; + """ + ) result = cur.fetchone() if result[0] < 1: - print("Failed Requirement: Total project cost is not 10x the amount of the CMF award.") + print( + "Failed Requirement: Total project cost is not 10x the amount of the CMF award." + ) # 3. Check for 60% in Areas of Economic Distress - cur.execute(""" - SELECT - SUM(CASE WHEN AreaOfEconomicDistress = 'Y' THEN TotalProjectCost ELSE 0 END) / - SUM(TotalProjectCost) * 100 AS PercentageInEconomicDistress - FROM Projects - JOIN ProjectMetrics ON Projects.txtPPN = ProjectMetrics.txtPPN AND ProjectMetrics.MetricID = 7; - """) - result = cur.fetchone() - if result[0] < 60: - print("Failed Requirement: Less than 60% of rental affordable housing units are in Areas of Economic Distress.") # 4. Check for each project having 20% for Low Income Families - cur.execute(""" + cur.execute( + """ SELECT txtPPN, (SUM(CASE WHEN MetricID IN (1,2,3,4) THEN MetricValue ELSE 0 END) / SUM(CASE WHEN MetricID = 7 THEN MetricValue ELSE 0 END)) * 100 AS PercentageForLowIncome FROM ProjectMetrics GROUP BY txtPPN; - """) + """ + ) projects = cur.fetchall() for project in projects: if project[1] < 20: - print(f"Project {project[0]} Failed Requirement: Less than 20% of affordable housing units for Low Income Families.") + print( + f"Project {project[0]} Failed Requirement: Less than 20% of affordable housing units for Low Income Families." + ) # Close the connection and commit changes conn.commit() cur.close() - return 'success' - return render_template('form.html') + return "success" + return render_template("form.html") -if __name__ == '__main__': - app.run(debug=True) +if __name__ == "__main__": + app.run(debug=True)