Декораторы типов SQLAlchemy и ошибки сравненияPython

Программы на Python
Ответить
Anonymous
 Декораторы типов SQLAlchemy и ошибки сравнения

Сообщение Anonymous »

Используя SQLAlchemy, я определил свой собственный TypeDecorator для хранения фреймов данных pandas в базе данных, закодированной как строка JSON.

class db_JsonEncodedDataFrameWithTimezone(db.TypeDecorator):
impl = db.Text

def process_bind_param(self, value, dialect):
if value is not None and isinstance(value, pd.DataFrame):
timezone = value.index.tz.zone
df_json = value.to_json(orient="index")
data = {'timezone': timezone, 'df': df_json, 'index_name': value.index.name}
value = json.dumps(data)
return value

def process_result_value(self, value, dialect):
if value is not None:
data = json.loads(value)
df = pd.read_json(data['df'], orient="index")
df.index = df.index.tz_localize('UTC')
df.index = df.index.tz_convert(data['timezone'])
df.index.name = data['index_name']
value = df
return value


Это отлично работает при первом сохранении базы данных, и загрузка тоже работает.

Проблема возникает, когда я увеличиваю значение, т. е. меняю DataFrame и пытаюсь изменить базу данных. Когда я вызываю

db.session.add(entity)
db.session.commit()


Я получаю обратную трассировку, которая указывает на то, что проблема заключается в сравнении значений:

x == y
ValueError: Can only compare identically-labeled DataFrame Objects.


Поэтому я подозреваю, что моя проблема как-то связана с принуждением компараторов. Я попробовал три вещи, но все они потерпели неудачу, и я действительно не знаю, что делать дальше:

#1st failed solution attempt inserting
coerce_to_is_types = (pd.DataFrame,)

#2nd failed solution attempt inserting
def coerce_compared_value(self, op, value):
return self.impl.coerce_compared_value(op, value)

#3rd failed solution attempt
class comparator_factory(db.Text.comparator_factory):
def __eq__(self, other):
try:
value = (self == other).all().all()
except ValueError:
value = False
return value


Подробнее здесь: https://stackoverflow.com/questions/467 ... son-errors
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Python»