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