| import dominate |
| from dominate.tags import meta, h3, table, tr, td, p, a, img, br |
| import os |
|
|
|
|
| class HTML: |
| """This HTML class allows us to save images and write texts into a single HTML file. |
| |
| It consists of functions such as <add_header> (add a text header to the HTML file), |
| <add_images> (add a row of images to the HTML file), and <save> (save the HTML to the disk). |
| It is based on Python library 'dominate', a Python library for creating and manipulating HTML documents using a DOM API. |
| """ |
|
|
| def __init__(self, web_dir, title, refresh=0): |
| """Initialize the HTML classes |
| |
| Parameters: |
| web_dir (str) -- a directory that stores the webpage. HTML file will be created at <web_dir>/index.html; images will be saved at <web_dir/images/ |
| title (str) -- the webpage name |
| refresh (int) -- how often the website refresh itself; if 0; no refreshing |
| """ |
| self.title = title |
| self.web_dir = web_dir |
| self.img_dir = os.path.join(self.web_dir, 'images') |
| if not os.path.exists(self.web_dir): |
| os.makedirs(self.web_dir) |
| if not os.path.exists(self.img_dir): |
| os.makedirs(self.img_dir) |
|
|
| self.doc = dominate.document(title=title) |
| if refresh > 0: |
| with self.doc.head: |
| meta(http_equiv="refresh", content=str(refresh)) |
|
|
| def get_image_dir(self): |
| """Return the directory that stores images""" |
| return self.img_dir |
|
|
| def add_header(self, text): |
| """Insert a header to the HTML file |
| |
| Parameters: |
| text (str) -- the header text |
| """ |
| with self.doc: |
| h3(text) |
|
|
| def add_images(self, ims, txts, links, width=400): |
| """add images to the HTML file |
| |
| Parameters: |
| ims (str list) -- a list of image paths |
| txts (str list) -- a list of image names shown on the website |
| links (str list) -- a list of hyperref links; when you click an image, it will redirect you to a new page |
| """ |
| self.t = table(border=1, style="table-layout: fixed;") |
| self.doc.add(self.t) |
| with self.t: |
| with tr(): |
| for im, txt, link in zip(ims, txts, links): |
| with td(style="word-wrap: break-word;", halign="center", valign="top"): |
| with p(): |
| with a(href=os.path.join('images', link)): |
| img(style="width:%dpx" % width, src=os.path.join('images', im)) |
| br() |
| p(txt) |
|
|
| def save(self): |
| """save the current content to the HMTL file""" |
| html_file = '%s/index.html' % self.web_dir |
| f = open(html_file, 'wt') |
| f.write(self.doc.render()) |
| f.close() |
|
|
|
|
| if __name__ == '__main__': |
| html = HTML('web/', 'test_html') |
| html.add_header('hello world') |
|
|
| ims, txts, links = [], [], [] |
| for n in range(4): |
| ims.append('image_%d.png' % n) |
| txts.append('text_%d' % n) |
| links.append('image_%d.png' % n) |
| html.add_images(ims, txts, links) |
| html.save() |
|
|