Я не думаю, что это имеет много значения для вектора. Я предпочитаю использовать индекс сам, поскольку я полагаю, что он более читаем, и можно сделать произвольный доступ как переходящий вперед 6 объектов или переходящий назад если потребности быть.
мне также нравится делать ссылку на объект в цикле как это, таким образом, нет большого количества квадратных скобок вокруг места:
for(size_t i = 0; i < myvector.size(); i++)
{
MyClass &item = myvector[i];
// Do stuff to "item".
}
Используя итератор может быть хорошим, если Вы думаете, что, возможно, должны были бы заменить вектор списком в какой-то момент в будущем, и это также выглядит более стильным к пятнам STL, но я не могу думать ни о какой другой причине.
Попробуйте решение из Reportlab .
Загрузите и установите его, как обычно, с помощью python setup.py install
Вам также потребуется установить следующие модули : xhtml2pdf, html5lib, pypdf с easy_install.
Вот пример использования:
Сначала определите эту функцию:
import cStringIO as StringIO
from xhtml2pdf import pisa
from django.template.loader import get_template
from django.template import Context
from django.http import HttpResponse
from cgi import escape
def render_to_pdf(template_src, context_dict):
template = get_template(template_src)
context = Context(context_dict)
html = template.render(context)
result = StringIO.StringIO()
pdf = pisa.pisaDocument(StringIO.StringIO(html.encode("ISO-8859-1")), result)
if not pdf.err:
return HttpResponse(result.getvalue(), content_type='application/pdf')
return HttpResponse('We had some errors<pre>%s</pre>' % escape(html))
Затем вы можете использовать ее так:
def myview(request):
#Retrieve data or whatever you need
return render_to_pdf(
'mytemplate.html',
{
'pagesize':'A4',
'mylist': results,
}
)
Шаблон:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>My Title</title>
<style type="text/css">
@page {
size: {{ pagesize }};
margin: 1cm;
@frame footer {
-pdf-frame-content: footerContent;
bottom: 0cm;
margin-left: 9cm;
margin-right: 9cm;
height: 1cm;
}
}
</style>
</head>
<body>
<div>
{% for item in mylist %}
RENDER MY CONTENT
{% endfor %}
</div>
<div id="footerContent">
{%block page_foot%}
Page <pdf:pagenumber>
{%endblock%}
</div>
</body>
</html>
Надеюсь, это поможет.