我正在学习python。这也是我的第一个堆叠式问题,并且在格式化输出以表明我的要求方面努力挣扎。我正在编写用于将带有逗号分隔值的字符串转换为级别层次结构显示数据的Python代码。
s = "(id,cb,e(id,fn,eT(id), ln),lc)"
我想要这样的输出
-id
-cb
-e
--id
--fn
--eT
---id
--ln
-lc
到目前为止,我已经进行了一些编码,但是我正在努力完善它。
class parent-child():
stack = []
def tree_recur(self,employee, level):
s = s[s.index("(")+1:s.rindex(")")]
ind = 0
while(s.rstrip != null or s != ""):
ss = s.index(",")
words = s[ind:ss]
parenind = words.index("(")
if parenind == -1:
stack.append(level,words)
s = s[ss+1:len(s)]
else:
stack.append(s[ss+1:parenind-1])
closeparenind = s.index(")")
ss1= s[parenind:closeparenind]
return tree_recur(self,ss1,level+1)
def main():
s = "(id,created,employee(id,firstname,employeeType(id), lastname),location)"
level = 0
print(E = parent-child(s, level))
main()
有人可以帮助我完善此代码。我不知道如何在字符串之前打印" - ",具体取决于水平的深度。那是1级的一条连字符,2级两个连字符,3级三连字符,并在括号关闭时向上移动一个水平。我要感谢您在帮助我方面的帮助和时间。
,因为您已经在尝试解析。简单的方法是通过每个字符迭代。
s = "(id,cb,e(id,fn,eT(id), ln),lc)"
hyphens = 0
result = []
current = ""
for c in s:
if c == "(": hyphens += 1
if c == ")": hyphens -= 1
if c.isalnum():
if not current:
current += "-" * hyphens
current += c
elif current:
result.append(current)
current = ""
result = " ".join(result)
print(result)
打印:
-id -cb -e --id --fn --eT ---id --ln -lc
编辑:
我可以理解您想要这种格式:
-id
-cb
-e
--id
--fn
--eT
---id
--ln
-lc
可以通过更改来完成:
current += " " * 2 * (hyphens - 1) + "-" * hyphens
和
result = "n".join(result)