Bỏ qua để đến Nội dung
Menu
Câu hỏi này đã bị gắn cờ
1 Trả lời
5820 Lượt xem

Hi dears odoo community,

please, is there a way to change the timezone infos to a specific datetime field on odoo, not to apply to all the context of current user, but to a specific one.

Because whene i try to change it via .replace(tzinfo) i got this error:

ValueError: Datetime field expects a naive datetime: 2020-12-18 14:36:06+00:00

and if i try to assign it using tostring method , i dont see any changes , value on database still on db and there is a difference between two value on the client and on the db,

rec.my_dt = fields.Datetime.to_string(rec.my_dt.astimezone(timezone('UTC')))

i want them two on utc.

thanks in advance.

Ảnh đại diện
Huỷ bỏ

Have you found any solution?

Câu trả lời hay nhất

You can't do that on an Odoo Datetime field as they are stored based on UTC.

What you can do is to add another field to the model and store into this your expected Datetime, adding to it the hours of your timezone, knowing that for the system will still be an UTC value.

It should be something like this:

from datetime import timedelta
Class InheditedClass(models.Model):
   _inherited = 'inherited.class'
    my_datetime = fields.Datetime(string="My datetime")
    def my_logic(self):
       self.my_datetime = original_datetime + timedelta(hours=1) # change 1 with your hours
Ảnh đại diện
Huỷ bỏ
Bài viết liên quan Trả lời Lượt xem Hoạt động
1
thg 8 21
6353
0
thg 7 21
2674
3
thg 5 18
7884
2
thg 8 25
2410
1
thg 7 25
909