| | 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()
|
| |
|