0

我最近得到了一个用于生成 HTML 的文件,一个菜单模板,由于时间限制,python 原型可以工作,但它是蛮力的,只适用于这种情况。

我知道必须有更好的方法来做到这一点,但我的谷歌搜索没有帮助。这是模板文件的样子

[text](link)
[text](link)
>[text](link)
>[text](link) 
>>[text](link)
>>[text](link)
>>[text](link)
[text](link)
>[text](link)

我已经设法将它强行强制到这个结构中(希望不会错过 ] 或 [ 某处 XD)

[
    [ [text](link), [] ],
    [ [text](link), [
        [ [text](link), [] ],
        [ [text](link), [
            [ [text](link), [] ],
            [ [text](link), [] ],
            [ [text](link), [] ], 
        ] ],
    ],
    [ [text](link), [
        [ [text](link), [] ],
    ] ],
]

但我基本上是通过跟踪根、父级然后在行的开头检查“”、“>”或“>>”然后将 [ text, [] ] 附加到“ ",“>”的根和“>>”的根[父]。问题是我想解决N*>问题,但我不确定如何继续,甚至不知道要搜索什么。在 Python 中,答案可以是任何语言,Python 是最快的组合

menu = []
f = open('template_file', 'r')
root = 0
parent = 0
for line in f:
    line = line.strip()
    m = re.match('(.*)(\[.*)', line)
    if m:
        prefix = m.group(1)
        link = m.group(2)
        if prefix == "":
            menu.append([link, []])
            root += 1
            parent = 0
        elif prefix == ">":
            menu[root - 1][1].append([link, []])
            parent += 1
        elif prefix == ">>":
            menu[root - 1][1][parent - 1][1].append([link, []])

所以这可行,但看起来很糟糕我不确定我应该搜索什么来找到将这些模板文件解析为这些结构的更好方法,以便我可以吐出必要的 HTML。我想防止问题进一步发生。

非常感激。

4

1 回答 1

0

用制表符替换每个“>”。输出几乎与您的蛮力输出完全相同。(file.txt 是你上面的模板文件)

test = open("file.txt", "r")

for line in test:
    print line.replace(">", "\t")
    #print line
于 2013-06-14T18:33:34.757 回答