-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcheckAddressFields.py
120 lines (94 loc) · 4.13 KB
/
checkAddressFields.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
import arcpy
import re
blankVals = ['', ' ', None]
def dirCheck(dir):
dirList = ['N', 'S', 'E', 'W', 'NORTH', 'SOUTH', 'EAST', 'WEST',\
'North', 'South', 'East', 'West', ' ', '', None]
if dir in blankVals:
return ''
else:
if dir.strip() not in dirList:
return '[Bad pre/suf direction]'
else:
return ''
def checkAddNum(addNum):
if addNum == None:
return '[Bad address number]'
elif addNum.isdigit() is False:
return '[Bad address number]'
else:
return ''
def checkStreetType(sType):
sTypeList = {'ALY', 'ALLEY', 'AVE', 'AVENUE', 'BAY', 'BND', 'BEND', 'BLVD', 'BOULEVARD', 'CYN', 'CANYON', \
'CTR', 'CENTER', 'CIR', 'CIRCLE', 'COR', 'CORNER', 'CT', 'COURT', 'CV', 'COVE', 'CRK', 'CREEK', \
'CRES', 'CRESCENT', 'XING', 'CROSSING', 'DR', 'DRIVE', 'EST', 'ESTATE', 'ESTS', 'ESTATES', \
'EXPY', 'EXPRESSWAY', 'FLT', 'FLAT', 'FRK', 'FORK', 'FWY', 'FREEWAY', 'GLN', 'GLEN', 'GRV', 'GROVE', \
'HTS', 'HEIGHTS', 'HWY', 'HIGHWAY', 'HL', 'HILL', 'HOLW', 'HOLLOW', 'JCT', 'JUNCTION', 'LN', 'LANE', \
'LOOP', 'MNR', 'MANOR', 'MDW', 'MEADOW', 'PARK', 'PKWY', 'PARKWAY', 'PASS', 'PL', 'PLACE', 'PLZ', \
'PLAZA', 'PT', 'POINT', 'RAMP', 'RNCH', 'RANCH', 'RDG', 'RIDGE', 'RD', 'ROAD', 'RTE', 'ROUTE', \
'ROW', 'RUN', 'SQ', 'SQUARE', 'ST', 'STREET', 'TER', 'TERRACE', 'TRCE', 'TRACE', 'TRL', 'TRAIL', \
'VW', 'VIEW', 'VLG', 'VILLAGE', 'WY', 'WAY', ' ', '', None}
if sType != None:
if sType.strip() not in sTypeList:
return '[Bad Street Type]'
else:
return ''
else:
return ''
def createStreetDict(cofips):
global rdDict
rdDict = {}
sgid10 = r'Database Connections\dc_agrc@[email protected]'
roadsFC = sgid10 + '\\SGID10.TRANSPORTATION.Roads'
sql = f""""COFIPS" = '{cofips}'"""
roadsFL = arcpy.MakeFeatureLayer_management(roadsFC, 'roadsFL', sql)
#rdFlds = ['STREETNAME', 'ZIPRIGHT']
rdFlds = ['STREETNAME', 'ADDR_SYS']
with arcpy.da.SearchCursor(roadsFL, rdFlds) as sCursor:
for row in sCursor:
rdName = row[0]
key = row[1]
if key not in rdDict:
rdDict[key] = list()
rdDict[key].append(rdName)
def countyRoadList(cofips):
global countyRdList
countyRdList = []
sgid10 = r'Database Connections\dc_agrc@[email protected]'
roadsFC = sgid10 + '\\SGID10.TRANSPORTATION.Roads'
sql = f""""COFIPS" = '{cofips}'"""
roadsFL = arcpy.MakeFeatureLayer_management(roadsFC, 'roadsFL', sql)
rdFlds = ['STREETNAME']
with arcpy.da.SearchCursor(roadsFL, rdFlds) as sCursor:
for row in sCursor:
rdName = row[0]
set(countyRdList.append(rdName))
def flagDuplicates(addressPts, objectID, addsysFld, fullAddFld, flagFld):
addDict = {}
with arcpy.da.SearchCursor(addressPts, [objectID, addsysFld, fullAddFld]) as sCursor:
empty = [None, '', ' ']
for row in sCursor:
if row[1] and row[2] not in empty:
addKey = f'{row[1]} {row[2]}'
objectid = row[0]
if addKey not in addDict:
addDict[addKey] = list()
addDict[addKey].append(objectid)
with arcpy.da.UpdateCursor(addressPts, [objectID, addsysFld, fullAddFld, flagFld]) as uCursor:
for row in uCursor:
addKey = f'{row[1]} {row[2]}'
if addKey in addDict:
if len(addDict[addKey]) > 1:
row[3] = f'{row[3]} [Duplicate address]'
uCursor.updateRow(row)
def checkStreetName(sName, key): # key can be either zip or addSys
errorList = [None, '', ' ', '00']
if sName in errorList:
return '[Street name error]'
if key in rdDict:
if sName.strip() not in rdDict[key]:
return '[Possible street name or add sys error]'
if re.match(r'.*[%\$\^\*\@\!\?\&\~\#\*\_\(\)\:\;\'\"\{\}\[\]].*', sName):
return '[Street name error]'
else:
return ''