python 基于左括号和右括号的逗号分隔字符串的目录结构显示
python Directory structure display of comma delimited string based on open and closed parentheses
我正在学习python。这也是我的第一个 Whosebug 问题,并且努力格式化输出以显示我的要求。
我正在编写 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)
我正在学习python。这也是我的第一个 Whosebug 问题,并且努力格式化输出以显示我的要求。 我正在编写 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)