I think you should be able to access the query sets directly in your
template. Not sure why that didn't work for you.

Here they pass a queryset to render_to_response:
http://www.djangoproject.com/documentation/tutorial03/#a-shortcut-render-to-response

Put a loop in your template and then access attributes of the loop variable
and you should be good. Here's another example:
http://www.djangoproject.com/documentation/tutorial03/#write-views-that-actually-do-something
They pass latest_poll_list to the template and then look at the template
where they have:

{% if latest_poll_list %}
    <ul>
    {% for poll in latest_poll_list %}
        <li>{{ poll.question }}</li>
    {% endfor %}
    </ul>
{% else %}
    <p>No polls are available.</p>
{% endif %}


You should be able to get rid of your get_tags and get_all_entries
functions, or at the very least replace them with something that returns a
queryset rather than constructing a list of dictionaries.

Dave

On Jan 10, 2008 4:12 AM, Matic Žgur <[EMAIL PROTECTED]> wrote:

>
> Hi everybody,
>
> being new in Django, I'd like to ask you for some tips about what
> should be in views.py and what shouldn't be.
>
> I'm writing a blog app with custom views.py. I know that it would be a
> lot easier (and wiser) to use generic views for what I'm trying to
> accomplish, but I'd like to learn new things along the way, so I
> decided to write my own views.py. Anyway, that's what bugs me:
>
> def get_all_tags():
>
>    tags = []
>    tags_db = Tag.objects.all()
>
>    for tag in tags_db:
>        tags.append({
>            'tag': tag.tag,
>            'url': tag.get_absolute_url()
>            })
>
>    return tags
>
> def get_entries_list(entries_list):
>
>    entries = []
>
>    for entry in entries_list:
>        entries.append({
>            'body': mark_safe(entry.body),
>            'pub_date': entry.pub_date,
>            'title': entry.title,
>            'url': entry.get_absolute_url(),
>            'tags': entry.get_tags(),
>            })
>
>    return entries
>
> def show_entries_by_day(request, year, month, day):
>    now = datetime.datetime.now()
>
>    # Check if day is in the future
>    if year + month + day > ''.join([str(now.year), str(now.month),
> str(now.day)]):
>        raise Http404
>
>    entries = Entry.objects.filter(pub_date__lte=now,
>                                      pub_date__year=year,
>                                      pub_date__month=month,
>                                      pub_date__day=day,
>                                      status=1)
>
>    return render_to_response('blog_entry.html', {'entries':
> get_entries_list(entries), 'tags': get_all_tags()})
>
> I have a function similar to show_entries_by_year() for month, day,
> tag and slug. Now, for get_all_tags(), I'm planning to write a
> template tag that would replace this function, but I still don't know
> what to do with get_entries_list(). I only made this function in order
> to not repeat myself. Is there a way to get rid of get_entries_list()
> and somehow make my views.py cleaner? I tried to pass entries directly
> to the template but it didn't quite work (maybe I'm missing
> something).
>
> I searched the web for some examples, but it's hard to find apps that
> don't use generic views (at least I didn't find them), so I decided to
> ask here.
>
> Thanks
> Matic Žgur
>
> >
>


-- 
David Grant
http://www.davidgrant.ca

--~--~---------~--~----~------------~-------~--~----~
You received this message because you are subscribed to the Google Groups 
"Django users" group.
To post to this group, send email to django-users@googlegroups.com
To unsubscribe from this group, send email to [EMAIL PROTECTED]
For more options, visit this group at 
http://groups.google.com/group/django-users?hl=en
-~----------~----~----~----~------~----~------~--~---

Reply via email to