I have a Django project for managing a list of journal articles. The main model is Article
. This has various fields to store things like title of the article, publication date, subject, as well as list of companies mentioned in the article. (company
is it's own model).
I want a template that prints out a list of the articles, sorted by category, and also listing the companies mentioned.
However, I'm hitting two issues.
Firstly, the company
field is a ManyToMany field. I'm printing this successfully now, using the all
iterable, thanks to this SO question =). (Curious though, where is this all
iterable documented in the Django documentation?)
listing objects from ManyToManyField
However, I'd like to print ", " (comma followed by space) after each item, except the last item. So the output would be:
Joe Bob Company, Sarah Jane Company, Tool Company
and not:
Joe Bob Company, Sarah Jane Company, Tool Company,
How do you achieve this with Django's templating system?
Secondly, each Article
has a CharField, called category
, that stores the category for the article. I would like the articles sorted by Categories, if possible. So I use QuerySet, and get a nice list of relevant articles in article_list. I then use the regroup
template tag to sort this into categories and print each one.
{ 'tennis': ('article_4', 'article_5')
'cricket': ('article_2', 'article_3')
'ping pong': ('article_1')
}
However, I need to make sure that my input list is sorted, before I pass it to regroup
. My question is, is it better to use the dictsort
template-tag to sort this inside the template, or should I use QuerySet's order_by
call instead?
And I assume it's better to use regroup
, rather than trying to code this myself in Python inside the view?
Cheers, Victor