X-Git-Url: https://git.mdrn.pl/librarian.git/blobdiff_plain/b416c7d130f17ac3191d2ef39492cd7c4f70bef7..d7ba2c607dacf7a6136b83a1588b5adf2278ad46:/librarian/html.py?ds=sidebyside diff --git a/librarian/html.py b/librarian/html.py index 1c141f3..5974d93 100644 --- a/librarian/html.py +++ b/librarian/html.py @@ -268,10 +268,12 @@ def extract_annotations(html_path): """For each annotation, yields a tuple: anchor, text, html.""" parser = etree.HTMLParser(encoding='utf-8') tree = etree.parse(html_path, parser) - for footnote in tree.find('//*[@id="footnotes"]').findall('div'): - anchor = footnote.find('a[@href]').get('href') - del footnote[:2] - text_str = etree.tostring(footnote, method='text', encoding='utf-8') - html_str = etree.tostring(footnote, method='html', encoding='utf-8') - yield anchor, text_str, html_str + footnotes = tree.find('//*[@id="footnotes"]') + if footnotes is not None: + for footnote in footnotes.findall('div'): + anchor = footnote.find('a[@name]').get('name') + del footnote[:2] + text_str = etree.tostring(footnote, method='text', encoding='utf-8').strip() + html_str = etree.tostring(footnote, method='html', encoding='utf-8') + yield anchor, text_str, html_str