preparing southern asset lists

This commit is contained in:
Khalim Conn-Kowlessar 2025-07-01 19:20:32 +01:00
parent 8a656cbff8
commit 7c3d8caea4
5 changed files with 53 additions and 37 deletions

View file

@ -1996,24 +1996,6 @@ class AssetList:
self.standardised_asset_list[col]
)
blocks_of_flats = self.standardised_asset_list[
self.standardised_asset_list[self.STANDARD_PROPERTY_TYPE] == "block of flats"
]
non_blocks_of_flats = self.standardised_asset_list[
self.standardised_asset_list[self.STANDARD_PROPERTY_TYPE] != "block of flats"
]
# Produce some aggregate figures
self.work_type_figures = {
**non_blocks_of_flats["cavity_reason"].value_counts().to_dict(),
**{
k + " (Block of flats)": v for k, v in
blocks_of_flats["solar_reason"].value_counts().to_dict().items()
},
**self.standardised_asset_list["solar_reason"].value_counts().to_dict()
}
# We prepare outcomes for output
if self.outcomes is not None:
logger.info("Preparing outcomes for output")
@ -2044,6 +2026,26 @@ class AssetList:
)
)
def get_work_figures(self):
blocks_of_flats = self.standardised_asset_list[
self.standardised_asset_list[self.STANDARD_PROPERTY_TYPE] == "block of flats"
]
non_blocks_of_flats = self.standardised_asset_list[
self.standardised_asset_list[self.STANDARD_PROPERTY_TYPE] != "block of flats"
]
# Produce some aggregate figures
self.work_type_figures = {
**non_blocks_of_flats["cavity_reason"].value_counts().to_dict(),
**{
k + " (Block of flats)": v for k, v in
blocks_of_flats["solar_reason"].value_counts().to_dict().items()
},
**self.standardised_asset_list["solar_reason"].value_counts().to_dict()
}
pprint(self.work_type_figures)
def fill_landlord_block_reference(self, has_blocks_of_flats):
if not has_blocks_of_flats:
return
@ -3245,6 +3247,8 @@ class AssetList:
scheme_col = "AFFORDABLE WARMTH"
elif "Scheme" in master_data.columns:
scheme_col = "Scheme"
elif "Affordable Warmth" in master_data.columns:
scheme_col = "Affordable Warmth"
else:
scheme_col = "OFFICE USE ONLY"

View file

@ -59,26 +59,26 @@ def app():
Property UPRN
"""
# Southern - Optivo list
data_folder = "/Users/khalimconn-kowlessar/Documents/hestia/Customers/Southern/New Programme"
data_filename = "OPTIVO List for Warmfront.xlsx"
sheet_name = "AddressProfilingResults"
postcode_column = 'PostCode'
fulladdress_column = "Address"
address1_column = None
address1_method = "house_number_extraction"
address_cols_to_concat = []
# Southern - Jan list
data_folder = "/Users/khalimconn-kowlessar/Documents/hestia/Customers/Southern/New Programme/Jan 2025 List"
data_filename = "SOUTHERN ASSETS January 2025 Additions Query 21.03.2025.xlsx"
sheet_name = "Jan 2025 additions"
postcode_column = 'Post Code'
fulladdress_column = None
address1_column = "NO."
address1_method = None
address_cols_to_concat = ["NO.", "Street / Block Name", "Town/Area"]
missing_postcodes_method = None
landlord_year_built = "Age"
landlord_year_built = None
landlord_os_uprn = None
landlord_property_type = None
landlord_built_form = None
landlord_wall_construction = "Walls"
landlord_roof_construction = "Roofs"
landlord_heating_system = "Heating"
landlord_property_type = "Archetype" # Using the inspections property type
landlord_built_form = "Archetype"
landlord_wall_construction = None
landlord_roof_construction = None
landlord_heating_system = None
landlord_existing_pv = None
landlord_property_id = "OrganisationReference"
landlord_sap = "SAP (9.92)"
landlord_property_id = "SH Property Reference"
landlord_sap = None
outcomes_filename = [
os.path.join(data_folder, "RT - Southern Housing Group - JJC.xlsx"),
os.path.join(data_folder, "RT - SOUTHERN OUTCOMES - SCIS Merged.xlsx"),
@ -634,6 +634,7 @@ def app():
# We now flag the status of the property
asset_list.label_property_status()
asset_list.analyse_geographies()
asset_list.get_work_figures()
# Store as an excel
filename = os.path.join(data_folder, ".".join(data_filename.split(".")[:-1])) + " - Standardised.xlsx"

View file

@ -340,4 +340,6 @@ HEATING_MAPPINGS = {
'Electric Storage Systems: Integrated storage+direct-acting heater': 'electric storage heaters',
'Boiler: D rated Combi': 'gas condensing combi',
'Heat Pump: (from database)': 'air source heat pump',
'Community Heating Systems: Community CHP and boilers (RdSAP)': 'communal heating',
'': 'unknown'
}

View file

@ -171,4 +171,8 @@ ROOF_CONSTRUCTION_MAPPINGS = {
'PitchedNormalLoftAccess: 250mm, PitchedNormalLoftAccess: 50mm': 'pitched insulated',
'AnotherDwellingAbove: Unknown, PitchedNormalLoftAccess: 200mm': 'another dwelling above',
'PitchedNormalNoLoftAccess: Unknown': 'pitched no access to loft',
'PitchedNormalLoftAccess: Unknown': 'pitched unknown insulation',
'AnotherDwellingAbove: Unknown': 'another dwelling above'
}

View file

@ -1,5 +1,5 @@
import time
import numpy as np
import random
import pandas as pd
from backend.SearchEpc import SearchEpc
from etl.find_my_epc.RetrieveFindMyEpc import RetrieveFindMyEpc
@ -172,7 +172,7 @@ def get_data(
find_epc_data = {}
except Exception as e:
raise Exception(f"Error retrieving FindMyEPC data: {e}")
time.sleep(np.random.uniform(0.1, 1))
time.sleep(random.sample(range(50, 100), 1)[0] / 100)
epc = {
row_id_name: home[row_id_name],
@ -182,6 +182,11 @@ def get_data(
}
epc_data.append(epc)
if len(epc_data) % 50 == 0 and len(epc_data) > 0:
logger.info("Sleeping for 10 seconds to avoid hitting API rate limit")
time.sleep(10)
except Exception as e:
errors.append(home[row_id_name])
time.sleep(5)