0

私はdjangoviews.pyで例を試しました:

import numpy as np
import matplotlib.pyplot as plt

N=3
Data = (1,2,9)
ind = np.arrange(N)
width = 0.35
p1 = plt.bar(ind, Data, width, color='r')

私が知らないこと-これをdjangoサイトのページに転送する方法。plt.show()を使用するか、pngオブジェクトのバッファーを作成してみますか?

これでごめんなさい...

4

2 に答える 2

2

これはあなたが探しているものです:

from matplotlib.backends.backend_agg import FigureCanvasAgg as FigureCanvas
import matplotlib.pyplot as plt 
import django

def plot(request):
    plt.plot()
    canvas = FigureCanvas(plt.figure(1))
    response=django.http.HttpResponse(content_type='image/png')
    canvas.print_png(response)
    return response
于 2011-07-14T23:26:33.283 に答える
1

私はそれをテストしていませんが、動作する可能性があります。キャンバスをpng形式で印刷するには、backend_aggを使用して、mimetype image/pngファイルとして処理する必要があります。

より良いアプローチは、文字を出力するためのビューを作成することのようです。

ビューは次のようになります。

import numpy as np
import matplotlib.pyplot as plt
from matplotlib.backends.backend_agg import FigureCanvasAgg as FigureCanvas
from matplotlib.figure import Figure
from django.http import HttpResponse

def bar_chart(request):
    if request.GET.get('data', False):
        data = (1,2,9)
    else:
        if type(request.GET['data']) == list():
            data = request.GET['data']

    chart = plt.bar(np.arange(3), data, 0.35, color='r')
    canvas = FigureCanvas(chart)
    response = HttpResponse(content_type='image/png')
    canvas.print_png(response)
    return response

# inside urls.py
#
# url(r'^charts/bar_chart.png$', 'myapp.views.charts.simple', name="bar_chart"),

また、テンプレートでは、次のように使用できます。

<h1>My Bar Char</h1>
<img src="{% url bar_chart %}?data=[10,20,40,50,30,50]" />

これにより、次のようにレンダリングされます。

<h1>My Bar Char</h1>
<img src="/charts/bar_chart.png?data=[10,20,40,50,30,50]" />

私はあなたがそれをテストしてこの答えを完成させることができることを願っています。

于 2011-02-14T22:31:45.557 に答える