ODOO 导出时间转化

odoo运行时时间有时忘记转换默认成了UTC时间,导致数据库中以及导出的文件中时间比实际的中国标准时间早8小时,故可以使用如下代码修改

#将如下代码复制到可执行的py文件中即可
import datetime, pytz
from odoo.fields import Datetime

Newdatetime = Datetime.convert_to_export

def convert_to_export(self, value, record):
    timezone = pytz.timezone('Asia/Shanghai')
    return_val = Newdatetime(self, value, record)
    if isinstance(return_val, datetime.datetime) and return_val:
        return self.to_string(return_val.replace(tzinfo=pytz.timezone('UTC')).astimezone(timezone))
    elif return_val:
        return self.to_string(self.from_string(return_val).replace(tzinfo=pytz.timezone('UTC')).astimezone(timezone))
    return return_val

Datetime.convert_to_export = convert_to_export
#获取当前系统时区
TimeZone timeZone1 = TimeZone.getDefault();

#获取所有时区ID
String[] availableIDs = TimeZone.getAvailableIDs();

#获取上海时区(Asia/Shanghai为上海时区ID)
TimeZone.getTimeZone("Asia/Shanghai");

#设置当前系统的默认时区为上海时区
TimeZone.setDefault(TimeZone.getTimeZone("Asia/Shanghai"));

#获取该TimeZone对象的时区名称
TimeZone timeZone = TimeZone.getTimeZone("Asia/Shanghai");
System.out.println(timeZone.getDisplayName()); # 中国标准时间
System.out.println(timeZone.getDisplayName(false, TimeZone.LONG)); # 中国标准时间
System.out.println(timeZone.getDisplayName(false, TimeZone.SHORT)); # CST

getDisplayName(boolean daylight, int style);
#daylight:若为true,则指定夏令时名称;若为false,则指定标准时间名称
#style:	TimeZone.LONG:显示全称
#		TimeZone.SHORT:显示简称

#获取该时间所在时区的时间偏移量
TimeZone timeZone = TimeZone.getTimeZone("Asia/Shanghai");
System.out.println(timeZone.getOffset(System.currentTimeMillis())); # 28800000

#设置时间原始偏移量
TimeZone timeZone = TimeZone.getTimeZone("Asia/Shanghai");
timeZone.setRawOffset(25200000);
System.out.println(timeZone.getRawOffset()); # 25200000
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值