0

Haystack と Whoosh を使用して、サイトの検索エンジン部分を構築しています。私の場合、Whooshは非常にうまく機能しますが、検索で見つかったものに応じて、ビューから追加情報を表示する必要があります。

私のDjangoビューでは、ダミーが表示する情報である次のようなものを使用します:

    dummy = "dummy"
    return render_to_response('images/ib_large_image.html', {'dummy': dummy},
                            context_instance=RequestContext(request))

したがって、基本的に、検索のビューをパーソナライズして、変数を検索テンプレートに表示したいと考えています。

ここにいくつかの設定があります:

設定:

    HAYSTACK_CONNECTIONS = {
    'default': {
    'ENGINE': 'haystack.backends.whoosh_backend.WhooshEngine',
    'PATH': os.path.join(os.path.dirname(__file__), 'whoosh_index'),
    'DEFAULT_OPERATOR': 'AND',
    'SITECONF': 'search_sites',
    'SEARCH_RESULTS_PER_PAGE': 20
        },
    }

search_sites.py :

    import haystack
    haystack.autodiscover()

検索 > インデックス > イメージボード > image_text.txt :

    {{ object.name }}
    {{ object.description }}

イメージボード > search_indexes.py :

    import datetime
    from haystack import indexes
    from imageboard.models import Image

    class ImageIndex(indexes.SearchIndex, indexes.Indexable):
        text = indexes.CharField(document=True, use_template=True)

        def get_model(self):
            return Image

        def index_queryset(self):
            """Used when the entire index for model is updated."""
            return self.get_model().objects.filter(uploaded_date__lte=datetime.datetime.now())

イメージボード > urls.py :

    urlpatterns = patterns('imageboard.views',
     (r'^search/', include('haystack.urls')),
    )

ビューを次のように構成しましたが、機能しません。

イメージボード > views.py :

    from haystack.views import SearchView
    def search(request):
       return SearchView(template='search.html')(request)

何か案が??

4

1 に答える 1

0

干し草の山「 StoredFields 」をご覧になることをお勧めします。これらは、検索結果ビューがアクセスする必要がある情報を検索インデックスに保存します。追加の利点は、コンテンツをレンダリングするために検索結果ビューが DB にアクセスする必要がないことです。さらに、各検索結果の出力を格納されたフィールドに事前にレンダリングできます。

class ImageIndex(indexes.SearchIndex, indexes.Indexable):
    rendered = CharField(use_template=True, indexed=False)

次に、search/indexes/myapp/image_rendered.txt という名前のテンプレート内で:

<h2>{{ object.title }}</h2>

<p>{{ object.content }}</p>

そして最後に、search/search.html で:

...

{% for result in page.object_list %}
    <div class="search_result">
        {{ result.rendered|safe }}
    </div>
{% endfor %}
于 2012-02-20T02:06:44.930 に答える