Django高级编程之自定义Field实现多语言
作者:Pykk2019 时间:2022-04-30 23:52:36
自定义数据库字段
扩展默认的models.CharField和models.TextField使之成为支持多语言的字段。
可以轻松实现复用,无需配置多余选项
from django.conf import settings
from django.db import models
from django.utils.translation import get_language
class MultilingualField(models.Field):
SUPPORTED_FIELD_TYPES = [models.CharField, models.TextField]
def __init__(self, verbose_name=None, **kwargs):
self.localized_field_model = None
for model in MultilingualField.SUPPORTED_FIELD_TYPES:
if issubclass(self.__class__, model):
self.localized_field_model = model
self._blank = kwargs.get("blank", False)
self._editable = kwargs.get("editable", True)
super().__init__(verbose_name, **kwargs)
@staticmethod
def localized_field_name(name, lang_code):
lang_code_safe = lang_code.replace("-", "_")
return f"{name}_{lang_code_safe}"
def get_localized_field(self, lang_code, lang_name):
_blank = (self._blank
if lang_code == settings.LANGUAGE_CODE
else True)
localized_field = self.localized_field_model(
f"{self.verbose_name} ({lang_name})",
name=self.name,
primary_key=self.primary_key,
max_length=self.max_length,
unique=self.unique,
blank=_blank,
null=False, # we ignore the null argument!
db_index=self.db_index,
default=self.default or "",
editable=self._editable,
serialize=self.serialize,
choices=self.choices,
help_text=self.help_text,
db_column=None,
db_tablespace=self.db_tablespace)
return localized_field
def contribute_to_class(self, cls, name,
private_only=False):
def translated_value(self):
language = get_language()
val = self.__dict__.get(
MultilingualField.localized_field_name(
name, language))
if not val:
val = self.__dict__.get(
MultilingualField.localized_field_name(
name, settings.LANGUAGE_CODE))
return val
# generate language-specific fields dynamically
if not cls._meta.abstract:
if self.localized_field_model:
for lang_code, lang_name in settings.LANGUAGES:
localized_field = self.get_localized_field(
lang_code, lang_name)
localized_field.contribute_to_class(
cls,
MultilingualField.localized_field_name(
name, lang_code))
setattr(cls, name, property(translated_value))
else:
super().contribute_to_class(
cls, name, private_only)
class MultilingualCharField(models.CharField, MultilingualField):
pass
class MultilingualTextField(models.TextField, MultilingualField):
pass
这里定义了 MultilingualCharField 和 MultilingualTextField字段
使用方法
settings.py
中配置多语言
LANGUAGE_CODE = 'zh-hans'
TIME_ZONE = 'Asia/Shanghai'
LANGUAGES = (
('en-us', 'US English'),
('zh-hans', 'Asia/Shanghai')
)
默认语言设置为中文,多语言为英语
models.py
中使用字段
from django.db import models
from django.utils.translation import ugettext_lazy as _
from utils.fields import (
MultilingualCharField,
MultilingualTextField
)
class Item(models.Model):
title = MultilingualCharField(_('Title'), max_length=200)
description = MultilingualTextField(_('Description'), blank=True)
content = MultilingualTextField(_('Content'))
def __str__(self):
return self.title
效果图
可以看到,数据库字段自动生成了相应语言的字段
当用户语言切换到其他,可以自动适配实现多语言
来源:https://www.cnblogs.com/PyKK2019/p/11117488.html
标签:Django,Field,多语言
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
python 工具 字符串转numpy浮点数组的实现
2023-07-15 20:37:16
![](https://img.aspxhome.com/file/2023/2/60952_0s.jpg)
python统计字符串中指定字符出现次数的方法
2022-11-17 11:37:46
python实现自动登录后台管理系统
2021-05-26 13:40:48
![](https://img.aspxhome.com/file/2023/3/107103_0s.jpg)
利用phpexcel对数据库数据的导入excel(excel筛选)、导出excel
2023-09-04 13:50:42
ASP防盗链及防下载的方法
2007-09-19 12:22:00
Python利用numpy实现三层神经网络的示例代码
2021-07-29 22:04:46
![](https://img.aspxhome.com/file/2023/0/80690_0s.jpg)
深入浅析Python传值与传址
2021-01-24 01:19:46
python开发之IDEL(Python GUI)的使用方法图文详解
2023-09-15 23:22:42
![](https://img.aspxhome.com/file/2023/8/62568_0s.png)
numpy中的converters和usecols用法详解
2021-01-23 18:29:29
![](https://img.aspxhome.com/file/2023/9/102779_0s.png)
pytorch中交叉熵损失函数的使用小细节
2021-08-30 05:02:21
利用MySQL加密函数保护Web网站敏感数据
2008-12-17 16:11:00
解决Python3用PIL的ImageFont输出中文乱码的问题
2022-09-09 04:49:22
![](https://img.aspxhome.com/file/2023/2/105572_0s.jpg)
分析并输出Python代码依赖的库的实现代码
2022-04-05 17:07:23
Python小白垃圾回收机制入门
2022-05-20 04:38:42
浅析python的Lambda表达式
2021-11-16 23:51:19
![](https://img.aspxhome.com/file/2023/4/71324_0s.png)
Python读取hdf文件并转化为tiff格式输出
2021-02-22 18:59:56
![](https://img.aspxhome.com/file/2023/2/77732_0s.png)
python操作 hbase 数据的方法
2022-07-21 15:46:51
说说CSS+Div布局中的结构与表现
2008-06-05 18:22:00
Python 常用模块 re 使用方法详解
2021-02-23 13:10:19
王孟友教你如何设计标志(LOGO)
2008-04-17 13:30:00