根据相邻的元组值连接python列表元组元素

时间:2018-08-22 07:10:32

标签: python python-3.x dictionary

我有一个像这样的列表:

[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]

怎么了?

4 个答案:

答案 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)