# Parse markdown table into tuple of lists
# Armaan Bhojwani 2021
-import sys
from bs4 import BeautifulSoup
import markdown
return outp
-def parse_html(html, args):
+def parse_html(html, args, conf):
"""Use BeautifulSoup to parse the HTML"""
def clean_text(inp):
soup = BeautifulSoup(html, "html.parser")
outp, ths = [], []
- for i, table in enumerate(soup.find_all("table")):
+ if args.table:
+ table_num = args.table
+ elif conf["table"]:
+ table_num = conf["table"]
+ else:
+ table_num = False
+
+ for i, table in enumerate(soup.find_all("table"), start=1):
ths = table.find_all("th")
if len(ths) != 2:
- if not args.lenient:
+ if conf["lenient"] or not args.lenient:
raise Exception("lightcards: Headings malformed")
- elif args.table == i:
+ elif (table_num and i == table_num) or not table_num:
try:
for x in table.find_all("tr"):
y = x.find_all("td")
sys.tracebacklimit = 0
global headers, stack
- (headers, stack) = parse.parse_html(parse.md2html(args.inp), args)
+ (headers, stack) = parse.parse_html(parse.md2html(args.inp), args, conf)
show(args, stack, headers, conf)