From d8cfa158610ee2cfc28d1a755fd77aa1e719689b Mon Sep 17 00:00:00 2001 From: Ernesto Perez Date: Mon, 18 Feb 2019 11:50:32 -0500 Subject: [PATCH] ENH: Expose SQLiteAdjustmentReader.get_df_from_table method. --- zipline/data/adjustments.py | 52 +++++++++++++++++++++---------------- 1 file changed, 29 insertions(+), 23 deletions(-) diff --git a/zipline/data/adjustments.py b/zipline/data/adjustments.py index a42c2f2430..70b76a98e0 100644 --- a/zipline/data/adjustments.py +++ b/zipline/data/adjustments.py @@ -197,33 +197,39 @@ def unpack_db_to_component_dfs(self, convert_dates=False): version of the table, where all date columns have been coerced back from int to datetime. """ + return { + t_name: self.get_df_from_table(t_name, convert_dates) + for t_name in self._datetime_int_cols + } - def _get_df_from_table(table_name, date_cols): - - # Dates are stored in second resolution as ints in adj.db tables. - # Need to specifically convert them as UTC, not local time. - kwargs = ( - {'parse_dates': {col: {'unit': 's', 'utc': True} - for col in date_cols} - } - if convert_dates - else {} + def get_df_from_table(self, table_name, convert_dates=False): + try: + date_cols = self._datetime_int_cols[table_name] + except KeyError: + raise ValueError( + "Requested table %s not found.\n" + "Available tables: %s\n" % ( + table_name, + self._datetime_int_cols.keys(), + ) ) - return pd.read_sql( - 'select * from "{}"'.format(table_name), - self.conn, - index_col='index', - **kwargs - ).rename_axis(None) + # Dates are stored in second resolution as ints in adj.db tables. + # Need to specifically convert them as UTC, not local time. + kwargs = ( + {'parse_dates': {col: {'unit': 's', 'utc': True} + for col in date_cols} + } + if convert_dates + else {} + ) - return { - t_name: _get_df_from_table( - t_name, - date_cols - ) - for t_name, date_cols in self._datetime_int_cols.items() - } + return pd.read_sql( + 'select * from "{}"'.format(table_name), + self.conn, + index_col='index', + **kwargs + ).rename_axis(None) class SQLiteAdjustmentWriter(object):