我有一个像这样的列表:
[16:51:19] Error while executing SQL query on database 'Company':
FOREIGN KEY constraint failed
我想将相邻的第一元组元素的第二元组元素值连接在一起,例如具有第一个元素0、1、2的元组应加入新的字符串“添加:净利润”,并应合并具有第一个元素4、5的元组变成新的字符串“ Less:Dep”。我已经尝试过了:
x = [(0, 'Add:'), (1, 'Net'), (2, 'Profit'), (4, 'Less:'), (5, 'Dep')]
它的输出为:
for i in range(len(x) -1):
if x[i+1][0] - x[i][0] == 1:
temp_str = x[i][1] + " " + x[i+1][1]
怎么了?
答案 0 :(得分:2)
您应该将问题划分为子问题。您希望组合单词组,因此需要列表中的单词并在其上使用join
。
您会获得具有groupby
功能的群组,为此您需要一个通用条件,例如列表中的位置与元组中的数字之间的差异。
from itertools import groupby
x = [(0, 'Add:'), (1, 'Net'), (2, 'Profit'), (4, 'Less:'), (5, 'Dep')]
for _, group in groupby(enumerate(x), lambda a:a[1][0] - a[0]):
words = [text for _, (_,text) in group] # extract words from data structure
print(' '.join(words))
答案 1 :(得分:1)
这不是有史以来最精美的Python代码,但这是一个很好的起点。
x = {0: 'Add:', 1: 'Net', 2: 'Profit', 4: 'Less:', 5: 'Dep'}
keys = sorted(x)
strings = []
temp=x[keys[0]]
for i, j in zip(keys, keys[1:]):
if j-i==1:
temp += ' ' + x[j]
else:
strings.append(temp)
temp=x[j]
strings.append(temp)
print(strings) # ['Add: Net Profit', 'Less: Dep']
答案 2 :(得分:1)
您要首先获取字典中的键并对它们进行排序,然后开始对键进行迭代,直到找到一个间隙,然后可以将所有值连接起来:
sorted_keys = sorted(x.keys())
start_index = 0
last_key = sorted_keys[0]
results = []
for i, cur_key in enumerate(sorted_keys):
if cur_key - last_key > 1:
# a gap has ended.
results.append(' '.join(x[k] for k in range(start_index, i)))
start_index = i
last_key = cur_key
if start_index != i:
results.append(' '.join(x[k] for k in range(start_index, i)))
答案 3 :(得分:0)
对于元组列表,您可以使用:
x = [(0, 'Add:'), (1, 'Net'), (2, 'Profit'), (4, 'Less:'), (5, 'Dep')]
indices = sorted([x[i][0] for i in range(len(x))])
out = [[]]
pos = 0
for i in range(len(x)):
out[pos].append(x[i][1])
if indices[i]+1 not in indices and indices[i] != max(indices):
out.append([])
pos += 1
out = [' '.join(i) for i in out ]
print(out)