Имам ModelForm с Django 2.1 и преместих няколко полета в друг модел. Извикването на make_migrations причинява грешка, тъй като тези полета не съществуват в текущия модел. Добавих някои от полетата към формуляра, но едно от полетата е TranslatedField (от django-translation-fields) и следователно в момента има 2 полета, а в бъдеще може да има и повече, в зависимост от броя на езиците. Името на полето е city и в момента получавам съобщение за грешка „Неизвестни полета (city_en, city_he), посочени за SiteProfile“ (защото използвам 2 езика - „en“ и „he“) - но аз искаме да създадем всички полета динамично с цикъл for над езиците, които използваме в проекта. Мога ли да заменя (и дали е добър метод за програмиране) метода __new__ или има друг начин? Предпочитам да не кодирам твърдо имената на полета (city_en и city_he), защото те могат да се променят в бъдеще, в зависимост от това колко езика използваме.

начин

Можете да видите текущия ми ангажимент (не работи) на GitHub.

И текущият код на този клон.

Бих искал да знам кой е най-добрият метод за програмиране за дефиниране на динамичен списък с полета (всички те са идентични и само едно от тях ще бъде използвано, другото ще бъде премахнато в метода __init__) в ModelForm, където полетата се запазват в друг модел (има 2 модела, но само една форма).

Все още не извърших миграциите поради тази грешка при стартиране на make_migrations.

(Дефинирах команда make_migrations, която прави само makemigrations)

Формата (с моя опит да замени __new__):

Актуализация 1: Мисля да дефинирам тези полета в метода __init__, докато ги премахвам от полетата в клас Meta, но дали е добър подход? За да дефинирате полета, които не са в списъка с полета ?

Django предупреждава да не се дефинират изрично полетата.

Силно се препоръчва да зададете изрично всички полета, които трябва да бъдат редактирани във формуляра, като използвате атрибута fields. Ако не го направите, лесно може да доведе до проблеми със сигурността, когато формуляр неочаквано позволява на потребителя да зададе определени полета, особено когато към модела се добавят нови полета. В зависимост от начина на визуализиране на формуляра, проблемът може дори да не се вижда на уеб страницата.

Алтернативният подход би бил да се включат автоматично всички полета или да се включат в черния списък само някои. Известно е, че този основен подход е много по-малко сигурен и е довел до сериозни експлойти на големи уебсайтове (напр. GitHub).

Искам да знам дали има решение без твърдо кодиране на езиците. В момента твърдо кодирах езиците:

Актуализация 2: Разбрах, че мога да добавя това поле динамично, като добавя този ред в метода __init__ на формуляра:

И след това да го премахнете от списъка с полета в клас Meta и от твърдо кодираната дефиниция в самата форма. Но полето се създава като последното поле във формата и искам да е в средата. Има ли начин да добавите това поле в средата?