Superset汉化

汉化配置

superset支持多种语言,其汉化文件在superset/translations,默认是英文,如果要使用中文可以在superset_config.py文件中进行配置

#设置默认语言为中文

BABEL_DEFAULT_LOCALE = "zh"

LANGUAGES = {

"zh": {"flag": "cn", "name": "简体中文"},

"en": {"flag": "us", "name": "English"},

}

然后重启服务就完成了

自定义汉化

官方的汉化有很多单词是错的;并且随着项目的更新,有些单词汉化更不上更新的速度,甚至没有翻译。想要自己去汉化就必须知道superset是怎么实现汉化的。

认识babel

在superset的后端py代码中使用了Flask-Babel来翻译,Flask-Babel是一个为Flask框架提供国际化和本地化(i18n/l10n)支持的插件,它基于Babel库来实现文本的翻译、数字格式化、日期格式化等功能。

使用babel

superset后端使用gettextlazy_gettext (或者别名_)方法,在前端使用ttn来进行翻译,如:gettext('translate me')t('translate me')

使用翻译工具时先确认是否安装了依赖

pip install -r superset/translations/requirements.txt

提取翻译字符串

使用gettextt等方法包含的字符串会被提取到.pot文件中,.pot文件是一个多语言的翻译模板文件。

提取字符串,这个脚本会提取前后端所有的翻译字符串:

./scripts/translations/babel_update.sh

更新翻译文件

后面我们需要根据.pot翻译模板文件生成新的.po语言文件:

pybabel update -i superset/translations/messages.pot -d superset/translations --ignore-obsolete

然后就可以开始翻译了,翻译位于 superset/translation 下的po文件中收集的字符串,其中每种语言都有一个文件夹。

pybabel update -i superset/translations/messages.pot -d superset/translations --ignore-obsolete

推荐一个翻译po文件的工具,可以更方便快捷的翻译:poedit。

编译翻译文件

前端
 

cd superset-frontend/ && npm ci

npm run build-translation

上面的命令会生成一个messages.json的文件供前端使用

后端

pybabel compile -d superset/translations

上面的命令会生成一个messages.mo的文件供后端使用

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值