-
Notifications
You must be signed in to change notification settings - Fork 13
/
FinalTablesStates.py
38 lines (35 loc) · 1.74 KB
/
FinalTablesStates.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
# -*- coding: utf-8 -*-
"""
Created on Thu Apr 30 13:11:33 2015
FinalTablesStates
@author: mweber
"""
import pandas as pd
import os
var = 'RefStreamTempPred'
# Read in a state / hydro-region lookup table
lookupdir = 'L:/Priv/CORFiles/Geospatial_Library_Projects/StreamCat/StateLookup'
stateVPU = pd.read_csv(lookupdir + '/State_VPU.csv')
stateVPU.head()
# let's convert thet states / VPUs in pandas data frame to a dictionary
g = stateVPU.groupby('NAME')
state_lookup = g['UnitID'].unique().to_dict()
# Read in states
for i in os.listdir(lookupdir):
if i.count('.csv') and not i.count('State_VPU') and not i.count('states_lookup') and not i.count('COMID_State'):
ST_NM = i.split('.')[0]
state = pd.read_csv(lookupdir + '/' + i)
count = 0
for VPU in state_lookup[ST_NM]:
if count == 0:
outtable = pd.read_csv('L:/Priv/CORFiles/Geospatial_Library_Projects/StreamCat/FTP_Staging/HydroRegions/' + var + '_Region' + VPU + '.csv')
outtable = outtable[outtable['COMID'].isin(state['COMID'])]
if count > 0:
temp = pd.read_csv('L:/Priv/CORFiles/Geospatial_Library_Projects/StreamCat/FTP_Staging/HydroRegions/' + var + '_Region' + VPU + '.csv')
temp = temp[temp['COMID'].isin(state['COMID'])]
outtable = pd.concat([outtable, temp], ignore_index = True)
count+=1
# grab state two letter code to use in writing out file
St_Abbr = pd.read_csv(lookupdir + '/states_lookup.csv')
St_Abbr_lookup = St_Abbr.set_index('STATE')['STATE_ABBR'].to_dict()
outtable.to_csv('L:/Priv/CORFiles/Geospatial_Library_Projects/StreamCat/FTP_Staging/States/' + var + '_' + St_Abbr_lookup[ST_NM] + '.csv',index=False)