0

こんにちは、mysql データベースから作業指示書を表示して電子メールに表示しようとしています。ただし、work_orders は Class Invoice manytomany フィールドの一部であるため、問題があります。これにより、このエラーが発生します。

'ManyRelatedManager' object has no attribute 'description'

何が問題なのかよくわかりません。ここに役立つかもしれない私のアプリの一部があります。

#views.py
@login_required
def invoice_mail(request, id=1):
    invoices_list = Invoice.objects.filter(pk=id)
    invoice = get_object_or_404(Invoice, pk=id)
    client = invoices_list[0].client
    invoice_no = invoices_list[0].invoice_no
    date = invoices_list[0].date
    work_orders = invoices_list[0].work_orders
    t = loader.get_template('registration/email.txt')
    c = Context({
    'client': client.company,
    'address':client.address,
    'city': client.city,
    'postcode': client.postcode,
    'email': client.email,
    'date': date,
    'invoice_no': invoice_no,
    'work_orders': work_orders.description,
    })
    send_mail('Welcome to My Project', t.render(c), 'jess@example.com', ['tom@example.com'], fail_silently=False)
    return render_to_response('sent_email.html', locals(), context_instance=RequestContext(request))


email.txt

INVOICE


Bill to:                            INVOICE # {{invoice_no}}
{{client}}                          DATE: {{date}}
{{address}}
{{city}}
{{postcode}}
{{email}}

quantity item Description
              {{work_orders.description}}
4

2 に答える 2

2

マネージャーに説明フィールドを追加しない限り、属性は存在しません (それが示すように)。多分あなたは使いたい

for order in work_orders.all():
    print order.description

またはテンプレートで

{% for order in work_orders.all }}
    {{ order.description }}
{% endfor %}

そして、おそらくコンテキストでそれを変更する必要があります

'work_orders': work_orders
于 2010-11-02T10:13:28.087 に答える
1

work_ordersリストではありません。これは、多対多フィールドのアクセサー/ORM マネージャーです。

実際の作業指示書を取得するには、メールに含めるために適切にフォーマットするために、戻ってきた各作業指示書を実行work_orders.all()(または) し、反復する必要があります。.filter(foo=bar)

于 2010-11-02T10:13:06.607 に答える