1

我正在尝试学习 pyqt 和一些 mvc 模式的东西。我还想为我的应用程序进行一些翻译。基本实验效果很好,所以我尝试在我的应用程序中实现它,但我现在在这里挣扎。

这是我初始化 QTranslator 的地方:

import sys

from PyQt5.QtCore import QTranslator
from PyQt5.QtWidgets import QApplication

from controller.main_controller import MainController


if __name__ == '__main__':
    KodiDBEditor = QApplication(sys.argv)
    translator = QTranslator(KodiDBEditor)
    translator.load("translate/de_DE.qm")
    KodiDBEditor.installTranslator(translator)
    main = MainController()
    sys.exit(KodiDBEditor.exec_())

我的控制器初始化视图,从模型中收集数据:

**snip**
    def init_ui(self):
        self.view.setWindowTitle(self.model.get_title())
        self.view.setGeometry(self.model.get_geometry())
        self.view.create_menus(self.model.get_menu())

在我看来,我有一个函数,它从字典创建菜单,字典本身是文件 constants.py 中的常量

**snip**
    def create_menus(self, menu):
        for i in menu:
            fm = self.menuBar().addMenu(i['label'])
            for j in i['action']:
                if j == '---':
                    fm.addSeparator()
                else:
                    action = QAction()
                    action.setParent(self)
                    action.setText(j['label'])
                    action.setIcon(QIcon.fromTheme(j['icon']))
                    action.setShortcut(j['shortcut'])
                    action.setStatusTip(j['statustip'])
                    fm.addAction(action)

常量.py:

from PyQt5.QtCore import QCoreApplication
translate = QCoreApplication.translate

MENU = (
    {'label': translate('MainModel', '&File'), 'action': (
        {'label': translate('MainModel','Export'), 'icon': '', 'shortcut': 'Ctrl+B', 'statustip': translate('MainModel','Export Database')},
        '---',
        {'label': 'E&xit', 'icon': 'application-exit', 'shortcut': 'Ctrl+Q', 'statustip': 'Exit Application'}
    )},
    {'label': '&Settings', 'action': (
        {'label': 'KodiDBEditor', 'icon': '', 'shortcut': '', 'statustip': 'Einstellungen für KodiDBEditor'},
    )},
    {'label': '&Hilfe', 'action': (
        {'label': 'Sub1', 'icon': '', 'shortcut': '', 'statustip': 'Sub1'},
        {'label': 'Sub2', 'icon': '', 'shortcut': '', 'statustip': 'Sub2'},
        {'label': 'Sub3', 'icon': '', 'shortcut': '', 'statustip': 'Sub3'}
    )}

)

但是,有问题的部分不会被翻译。(我创建了 ts 文件,在 QT linguist 中对其进行了编辑并构建了 qm 文件)

如果我放置一些单个代码,例如:

print(translate('MainModel', '&File'))

在我的代码中的任何地方,该字符串都被正确翻译此外,如果将 MENU 常量直接放入我的模型中,一切都很好。但是,我更喜欢使用单独的常量方法(因为会有更多)

所以问题是,为什么我的代码没有按原样翻译?

根据要求,一个简单的工作示例(minimal.py):

import sys

from PyQt5.QtCore import QCoreApplication
from PyQt5.QtCore import QTranslator
from PyQt5.QtWidgets import QApplication

from other import Main

translate = QCoreApplication.translate

if __name__ == '__main__':
    KodiDBEditor = QApplication(sys.argv)
    translator = QTranslator(KodiDBEditor)
    translator.load("translate/de_DE.qm")
    KodiDBEditor.installTranslator(translator)
    main = Main()
    sys.exit(KodiDBEditor.exec_())

(其他.py):

from PyQt5.QtCore import QCoreApplication
from PyQt5.QtWidgets import QMainWindow

from misc.constants import MENU


class Main(QMainWindow):
    def __init__(self):
        super().__init__()
        self.printstuff()
        self.show()

    def printstuff(self):
        translate = QCoreApplication.translate
        MENU2 = (
            {'label': translate('MainModel', '&File'), 'action': (
                {'label': translate('MainModel', 'Export'), 'icon': '', 'shortcut': 'Ctrl+B',
                 'statustip': translate('MainModel', 'Export Database')},
                '---',
                {'label': 'E&xit', 'icon': 'application-exit', 'shortcut': 'Ctrl+Q', 'statustip': 'Exit Application'}
            )},
            {'label': '&Settings', 'action': (
                {'label': 'KodiDBEditor', 'icon': '', 'shortcut': '', 'statustip': 'Einstellungen für KodiDBEditor'},
            )},
            {'label': '&Hilfe', 'action': (
                {'label': 'Sub1', 'icon': '', 'shortcut': '', 'statustip': 'Sub1'},
                {'label': 'Sub2', 'icon': '', 'shortcut': '', 'statustip': 'Sub2'},
                {'label': 'Sub3', 'icon': '', 'shortcut': '', 'statustip': 'Sub3'}
            )})
        print(MENU)  # tuple holding the menu dicts. strings are not translated, &File = &File
        print(translate('MainModel', '&File'))  # this is working &File = &Datei
        print(MENU2) #this is working as well

constants.py 如上

4

1 回答 1

1

好的,似乎是一个导入问题。如果我在 Qtranslator 初始化后导入 Main(它本身导入 MENU),一切正常。所以看起来 translate() 是在导入时执行的。有没有办法避免这种情况?现在我的解决方法是在设置操作文本时再次调用 translate。看起来有点hacky,但似乎工作。

于 2020-03-16T20:57:34.943 回答