or better

{{
import re
from gluon.contrib.markmin.markmin2pdf import markmin2pdf
def markmin_serializer(text,tag=None,attr={}):
    if tag==None: return re.sub('\s+',' ',text)
    if tag=='br': return '\n\n'
    if tag=='h1': return '# '+text+'\n\n'
    if tag=='h2': return '#'*2+' '+text+'\n\n'
    if tag=='h3': return '#'*3+' '+text+'\n\n'
    if tag=='h4': return '#'*4+' '+text+'\n\n'
    if tag=='p': return text+'\n\n'
    if tag=='li': return '\n- '+text.replace('\n',' ')
    if tag=='tr': return text[3:].replace('\n',' ')+'\n'
    if tag in ['table','blockquote']: return '\n-----\n'+text+'\n------
\n'
    if tag in ['td','th']: return ' | '+text
    if tag in ['b','strong','label']: return '**%s**' % text
    if tag in ['em','i']: return "''%s''" % text
    if tag in ['tt','code']: return '``%s``' % text
    if tag=='a': return '[[%s %s]]' % (text,attr.get('_href',''))
    return text
html=response.render('%s/%s.html' %
(request.controller,request.function))
markmin=TAG(html).element('#content').flatten(markmin_serializer)
pdf,warnings,errors=markmin2pdf(markmin)
if errors:
   response.headers['Content-Type']='text'
 
response.write(HTML(BODY(H1('errors'),LU(*errors),H1('warnings'),LU(*warnings))))
else:
   response.headers['Content-Type']='application/pdf'
   response.write(pdf,escape=False)
pass
}}


On Oct 2, 11:10 pm, mdipierro <[email protected]> wrote:
> install pdflatex
>
> create a views/generic.pdf that contains:
>
> ---- begin file ----
> {{
> import re
> from gluon.contrib.markmin.markmin2pdf import markmin2pdf
> def markmin_serializer(text,tag=None,attr={}):
>     if tag==None: return re.sub('\s+',' ',text)
>     if tag=='br': return '\n\n'
>     if tag=='h1': return '# '+text+'\n\n'
>     if tag=='h2': return '#'*2+' '+text+'\n\n'
>     if tag=='h3': return '#'*3+' '+text+'\n\n'
>     if tag=='h4': return '#'*4+' '+text+'\n\n'
>     if tag=='li': return '\n- '+text.replace('\n',' ')
>     if tag=='table': return '\n-----\n'+text+'\n------\n'
>     if tag=='tr': return text[3:].replace('\n',' ')+'\n'
>     if tag=='td': return ' | '+text
>     if tag=='p': return text+'\n\n'
>     if tag=='b' or tag=='strong': return '**%s**' % text
>     if tag=='em' or tag=='i': return "''%s''" % text
>     if tag=='tt' or tag=='code': return '``%s``' % text
>     if tag=='a': return '[[%s %s]]' % (text,attr.get('_href',''))
>     return text
> html=response.render('%s/%s.html' %
> (request.controller,request.function))
> markmin=TAG(html).element('#content').flatten(markmin_serializer)
> response.write(markmin2pdf(markmin)[0],escape=False)
> response.headers['content-type']='text'}}
>
> ---- end file---
>
> Now you should be able to view any web2py page with .pdf in pdf.
>
> I am sure this can also be done and better with pyfpdf but I have not
> tried. Perhaps Mariano can help us

Reply via email to