如何获得每个可能的列表案例总和

时间:2017-04-08 15:31:16

标签: python list for-loop indexing while-loop

您好我刚开始学习python。

我想在列表中创建数据的每个案例

if [a,b,c,d,e]

[aa, 'ab', 'ac', 'ad', 'ae', 'ba', 'bb', 'bc', 'bd', 'be'] and so on

但我无法弄明白该怎么做。

这是我可以去的地方:

def number_of_cases(list_data):

    mix_data=[]
    list_data = list(map(str,list_data))
    for data in list_data:
        mix_data.append(data+list_data[0])
        mix_data.append(data+list_data[1])
        mix_data.append(data+list_data[2])

我无法继续做list[0 1 2 3 4],因为我不知道该列表会有多长时间......

5 个答案:

答案 0 :(得分:3)

或者你可以做一个平面列表理解:

data = list('abcd')
pairs = [x+y for x in data for y in data]
pairs
# ['aa', 'ab', 'ac', 'ad', 'ba', 'bb', 'bc', 'bd', 'ca', 'cb', 'cc', 'cd', 'da', 'db', 'dc', 'dd']

顺便说一句,在这个特定的例子中,甚至不需要先列出一个列表

pairs = [x+y for x in 'abcd' for y in 'abcd']

也有效。

答案 1 :(得分:2)

考虑使用itertools.product?给定两个列表,它将创建一个列表中的项目和另一个列表中的项目的所有成对组合,作为元组序列。然后你将每个元组粘在一起。

from itertools import product
data = ['a', 'b', 'c', 'd']
pairs = [''.join(x) for x in product(data, data)]
print(pairs)

答案 2 :(得分:1)

@ AlexL&{39} product mix_data=[] list_data = ['a', 'b', 'c', 'd', 'e'] list_data = list(map(str,list_data)) for data1 in list_data: for data2 in list_data: mix_data.append(data1+data2) print(mix_data) 是可行的方法。这是代码的修改版本,具有所需的结果:

(3 4)

输出:

  

[' aa',' ab',' ac',' ad',' ae',& #39; ba',' bb',' bc',' bd',' be',' ca&# 39 ;,   ' cb',' cc',' cd',' ce',' da',' db& #39;,' dc',' dd',' de',' ea',' eb',   ' ec',' ed',' ee']

答案 3 :(得分:0)

您可以使用像@Alex L这样的itertools,或者您也可以使用这些简单的两个循环。

<?php

    //must have data:image/image-type;base64 if not then add it.you can use filedata in place of image variable.

    $image="";
?>
<table border=1>
    <tr>
        <td>Image</td>
        <td><img src=<?php echo ($image); ?>></td>
    </tr>
</table>

答案 4 :(得分:0)

我的第一个建议是不正确的,如下所述。这个答案仍然正确。

一个可爱而简洁的方法是使用列表推导和f-strings(f-string只在python 3.6及以上)。 EG:

chars = 'abcde'
pairs = ['{x}{y}' for x in chars for y in chars]

如果你没有f字符串,那么就是这样:

chars = 'abcde'
pairs = ([f'%s%s' % (x, y) for x in chars for y in chars])

>>>print(pairs) ['aa', 'ab', 'ac', 'ad', 'ae', 'ba', 'bb', 'bc', 'bd', 'be', 'ca', 'cb', 'cc', 'cd', 'ce', 'da', 'db', 'dc', 'dd', 'de', 'ea', 'eb', 'ec', 'ed', 'ee']