作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 list l
l = ['a','a','{','b','a','{','a','}','}','a']
我想把这个列表变成下面的列表。
print(new_l)
# ['a','a',['{','b','a',['{','a','}'],'}'],'a']
因此,基本上,大括号内的所有内容,包括大括号本身,都应该位于原始列表内的列表中。
print(new_l)
# ['a',['a','{','b',['a','{','a','}'],'}'],'a']
最佳答案
尝试这个
import json
def add_nested_lists(l):
ltemp = '['
last_element = ''
n = len(l)
for i in range(0, n):
element = l[i]
if element == '{':
if l[i-1] == "{":
last_element = '"{", '
ltemp = ltemp[0:len(ltemp) - len(last_element)]
ltemp += '[' + last_element + '"' + element + '", '
last_element = '[' + last_element + '"' + element + '", '
else:
ltemp = ltemp[0:len(ltemp) - len(last_element)]
ltemp += '[' + last_element + '"' + element + '", '
last_element = '[' + last_element + '"' + element + '", '
elif element == "}":
if i == n - 1:
ltemp += '"' + element + '"]' + ']'
last_element = '"' + element + '"]' + ']'
else:
ltemp += '"' + element + '"]' + ', '
last_element = '"' + element + '"]' + ', '
else:
if i == 0 or i != n - 1: # first element or middle elements
ltemp += '"' + element + '", '
last_element = '"' + element + '", '
elif i == n - 1: # last element
ltemp += '"' + element + '"]'
last_element = '"' + element + '"]'
print(ltemp)
ltemp = json.loads(ltemp)
return ltemp
l = ['a','a','{','{','b','a','{','a','}','}','a','}']
print(type(l), add_nested_lists(l))
输出
<class 'list'> ['a', ['a', ['{', '{', 'b', ['a', '{', 'a', '}'], '}'], 'a', '}']]
如果你可以并且想要更高的效率,那么尝试制作字符串而不是列表 'l'
import json
l = '['
last_element = ''
is_last_element_is_curly = False
def add(element, position='m'): # m - middle element
global l, last_element, is_last_element_is_curly
if element == '{':
if is_last_element_is_curly:
last_element = '"{", '
l = l[0:len(l) - len(last_element)]
l += '[' + last_element + '"' + element + '", '
last_element = '[' + last_element + '"' + element + '", '
else:
l = l[0:len(l) - len(last_element)]
l += '[' + last_element + '"' + element + '", '
last_element = '[' + last_element + '"' + element + '", '
is_last_element_is_curly = True
elif element == "}":
if position == 'l':
l += '"' + element + '"]' + ']'
last_element = '"' + element + '"]' + ']'
else:
l += '"' + element + '"]' + ', '
last_element = '"' + element + '"]' + ', '
is_last_element_is_curly = False
else:
if position == 'f' or position == 'm': # f - first element or m - middle element
postfix = '", '
l += '"' + element + '", '
last_element = '"' + element + '", '
elif position == 'l': # l - last element
l += '"' + element + '"]'
last_element = '"' + element + '"]'
is_last_element_is_curly = False
#Do you stuff here and add elements to string 'l'
ltemp = ['a','a','{','{','b','a','{','a','}','}','a','}']
add(ltemp[0], position="f")
for i in range(1,len(ltemp) - 1):
add(ltemp[i])
add(ltemp[i + 1], position="l")
print(l)
#After that it will become very efficient
l = json.loads(l)
print(type(l),l)
关于python - 有没有办法轻松地将 2 个索引之间的所有元素放入 Python 中的嵌套列表中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62507813/
我是一名优秀的程序员,十分优秀!