渡すデータの複雑さに応じて、いくつかのアプローチがあると思います。
https://docs.djangoproject.com/en/dev/ref/contrib/formtools/form-wizard/#providing-initial-data-for-the-formsの指示に従って
、最初の辞書を作成します。次のように urls.py のビューに渡します。
>>> initial = {
... '0': {'subject': 'Hello', 'sender': 'user@example.com'},
... '1': {'message': 'Hi there!'}
... }
>>> wiz = ContactWizard.as_view([ContactForm1, ContactForm2], initial_dict=initial)
もう 1 つのオプションは、これはより複雑ですが、もう少しロジックを追加できるようにするため、get_initkwargs をオーバーライドしてそこにロジックを配置することです (Django コード: https://github.com/django/django/blob/を参照)。 master/django/contrib/formtools/wizard/views.py )。
最後に、前のフォームの入力に基づいてオブジェクトを提供する必要がある場合、get_initkwargs はクラス メソッドであり、ウィザードの開始時に初期辞書を渡す必要があるため、非常に複雑になります。しかし、おそらく get_form_kwargs をオーバーライドすることでそれを行うことができます:
def get_form_kwargs(self, step=None):
kwargs = {}
if step != '0':
your_field = self.get_cleaned_data_for_step('0')['your_field']
# logic for getting object based on field goes here
kwargs.update({'object': object,})
return kwargs
次に、フォームのinitメソッドを使用して、kwargs で渡したオブジェクトに基づいて初期値を設定できます。最後のコードはよく使いますが、以前のものはあまり使用していません。